/* Monument Roofing - theme styles. Colours --gold/--ink/--cream are overridden from the Customizer. */
:root{
  --ink:#1C1F21; --ink-2:#24272A; --ink-3:#121416; --ink-4:#0E0F11;
  --gold:#C2A05A; --gold-lt:#E0C786; --gold-dk:#9A7B3B;
  --cream:#F4F3F1; --paper:#FFFFFF;
  --muted:#B7B3AA; --muted-2:#8B8881; --slate:#5C5A57;
  --line-d:rgba(255,255,255,.12); --line-l:rgba(24,24,24,.10);
  --shadow:0 24px 60px rgba(0,0,0,.4);
  --radius:14px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:'Hanken Grotesk',system-ui,-apple-system,sans-serif;color:#23262a;background:var(--cream);line-height:1.5;-webkit-font-smoothing:antialiased;}
img{display:block;max-width:100%;}
svg{display:block;}
a{color:inherit;text-decoration:none;}
.display{font-family:'Archivo',system-ui,sans-serif;}
.wrap{width:min(1160px,100% - 44px);margin-inline:auto;}
.section{padding:clamp(52px,7vw,92px) 0;}
h1,h2,h3,h4{font-family:'Archivo',system-ui,sans-serif;font-weight:800;line-height:1.05;letter-spacing:-.01em;}

/* eyebrow with peak motif */
.eyebrow{display:inline-flex;align-items:center;gap:11px;font-family:'Archivo';font-weight:700;text-transform:uppercase;letter-spacing:.22em;font-size:12.5px;color:var(--gold);}
.eyebrow svg{width:26px;height:13px;}
.sec-head{text-align:center;max-width:720px;margin:0 auto clamp(34px,4.5vw,52px);}
.sec-head h2{font-size:clamp(30px,4.4vw,46px);text-transform:uppercase;margin-top:16px;}
.sec-head p{margin-top:16px;font-size:17.5px;color:var(--slate);}
.on-dark .sec-head h2{color:#fff;} .on-dark .sec-head p{color:var(--muted);}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;font-family:'Archivo';font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:14.5px;padding:15px 28px;border-radius:9px;border:2px solid transparent;transition:transform .15s ease,background .15s ease,box-shadow .15s ease,color .15s ease;white-space:nowrap;}
.btn svg{width:18px;height:18px;}
.btn-gold{background:linear-gradient(135deg,var(--gold-lt),var(--gold));color:#1b1c17;box-shadow:0 10px 26px rgba(194,160,90,.32);}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(194,160,90,.42);}
.btn-outline{background:transparent;border-color:rgba(255,255,255,.4);color:#fff;}
.btn-outline:hover{background:rgba(255,255,255,.1);border-color:#fff;}
.btn-outline-gold{background:transparent;border-color:var(--gold);color:var(--gold-dk);}
.btn-outline-gold:hover{background:var(--gold);color:#1b1c17;transform:translateY(-2px);}

/* ===== TOP BAR ===== */
.topbar{background:var(--ink-4);color:var(--muted);font-size:12.5px;}
.topbar .wrap{display:flex;align-items:center;justify-content:center;gap:14px;padding:8px 0;text-align:center;}
.topbar .stars{color:var(--gold);letter-spacing:2px;}
.topbar b{color:#fff;font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-family:'Archivo';font-size:11.5px;}
.topbar .sep{color:var(--gold);opacity:.6;}

/* ===== BRAND LOCKUP ===== */
.brand{display:inline-flex;align-items:center;gap:14px;color:#fff;}
.brand-mark{color:var(--gold);flex:none;}
.brand-mark svg{width:54px;height:30px;}
.brand-text{display:flex;flex-direction:column;line-height:1;}
.bt-1{font-family:'Archivo';font-weight:800;letter-spacing:.28em;font-size:20px;color:#fff;}
.bt-2{display:flex;align-items:center;gap:8px;margin-top:4px;}
.bt-2 i{height:1px;width:18px;background:var(--gold);opacity:.7;}
.bt-2 span{font-family:'Archivo';font-weight:600;letter-spacing:.42em;font-size:10.5px;color:var(--gold);}
.bt-3{font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-top:5px;font-weight:600;}

/* ===== HEADER ===== */
.hdr{position:sticky;top:0;z-index:50;background:rgba(28,31,33,.94);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line-d);}
.hdr .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;height:84px;}
.hdr-right{display:flex;align-items:center;gap:22px;}
.hdr-phone{display:flex;align-items:center;gap:11px;}
.hdr-phone .ic{width:38px;height:38px;border-radius:50%;border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;flex:none;}
.hdr-phone .ic svg{width:17px;height:17px;color:var(--gold);}
.hdr-phone .lbl{display:block;font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);line-height:1.3;}
.hdr-phone .num{display:block;font-family:'Archivo';font-weight:800;font-size:19px;color:#fff;line-height:1.1;}
.hdr-call-mini{display:none;}

/* ===== HERO ===== */
.hero{position:relative;isolation:isolate;background:var(--ink);overflow:hidden;}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;background:var(--hero-bg) center/cover;opacity:.16;}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(120% 90% at 80% 0,rgba(194,160,90,.10),transparent 55%),linear-gradient(180deg,rgba(28,31,33,.78),rgba(18,20,22,.96));}
.hero-peaks{position:absolute;right:-40px;top:40px;z-index:-1;width:520px;max-width:55%;color:var(--gold);opacity:.07;}
.hero .wrap{display:grid;grid-template-columns:1.06fr .94fr;gap:52px;align-items:center;padding:clamp(46px,5vw,76px) 0 clamp(52px,5vw,82px);}
.hero-pill{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--gold);color:var(--gold);font-family:'Archivo';font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:12px;padding:8px 16px;border-radius:40px;}
.hero-pill svg{width:14px;height:14px;}
.hero h1{color:#fff;font-size:clamp(42px,6vw,74px);text-transform:uppercase;margin:22px 0 0;line-height:.98;}
.hero h1 .hl{color:var(--gold);}
.hero-sub{color:#e7e3da;font-size:clamp(17px,1.8vw,21px);font-weight:500;margin-top:18px;max-width:32ch;}
.hero-stat{display:inline-flex;align-items:center;gap:12px;margin-top:20px;}
.hero-stat .n{font-family:'Archivo';font-weight:800;font-size:30px;color:var(--gold);}
.hero-stat .t{font-size:13.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600;line-height:1.2;max-width:16ch;}
.hero-ticks{list-style:none;margin:26px 0 0;display:flex;flex-direction:column;gap:12px;}
.hero-ticks li{display:flex;align-items:center;gap:12px;color:#ece8df;font-size:15.5px;font-weight:500;}
.hero-ticks .tk{width:23px;height:23px;border-radius:50%;border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;flex:none;}
.hero-ticks .tk svg{width:12px;height:12px;color:var(--gold);}
.hero-callrow{margin-top:28px;display:flex;align-items:center;gap:16px;}
.hero-callrow .or{color:var(--muted-2);font-size:14px;}
.hero-callrow a.phone{font-family:'Archivo';font-weight:800;font-size:23px;color:#fff;display:inline-flex;align-items:center;gap:9px;}
.hero-callrow a.phone svg{width:19px;height:19px;color:var(--gold);}

/* quote card */
.quote-card{background:var(--paper);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;scroll-margin-top:100px;border:1px solid rgba(194,160,90,.25);}
.quote-head{background:var(--ink-2);color:#fff;padding:22px 26px;border-bottom:2px solid var(--gold);}
.quote-head h2{font-size:25px;text-transform:uppercase;color:#fff;}
.quote-head p{font-size:13px;color:var(--gold-lt);margin-top:6px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;}
.quote-form{padding:24px 26px 26px;}
.fld{margin-bottom:14px;}
.fld label{display:block;font-size:12px;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px;}
.fld label .req{color:var(--gold-dk);}
.fld input,.fld select,.fld textarea{width:100%;font-family:inherit;font-size:15.5px;color:#23262a;background:#fff;border:1.6px solid #d3cfc6;border-radius:9px;padding:12px 13px;transition:border-color .15s ease,box-shadow .15s ease;}
.fld textarea{resize:vertical;min-height:64px;}
.fld input::placeholder,.fld textarea::placeholder{color:#a7a299;}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(194,160,90,.2);}
.fld input[aria-invalid="true"],.fld select[aria-invalid="true"]{border-color:#c0392b;background:#fdf6f5;}
.fld .err{display:none;color:#c0392b;font-size:12px;font-weight:600;margin-top:5px;}
.fld.invalid .err{display:block;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.quote-form .btn-gold{width:100%;margin-top:6px;font-size:16px;padding:16px;}
.quote-fine{margin-top:13px;font-size:12.5px;color:var(--slate);text-align:center;line-height:1.5;}
.quote-fine a{color:var(--ink);font-weight:700;}
.quote-done{display:none;padding:42px 28px 46px;text-align:center;}
.quote-done .ok{width:66px;height:66px;border-radius:50%;background:rgba(194,160,90,.14);border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 18px;}
.quote-done .ok svg{width:32px;height:32px;color:var(--gold-dk);}
.quote-done h3{font-size:25px;text-transform:uppercase;color:var(--ink);}
.quote-done p{margin-top:11px;color:var(--slate);font-size:15px;}
.quote-done .cb{margin-top:18px;font-family:'Archivo';font-weight:800;font-size:21px;color:var(--ink);}
.is-sent .quote-form{display:none;} .is-sent .quote-done{display:block;}

/* ===== TRUST STRIP ===== */
.tstrip{background:var(--ink-4);border-top:1px solid var(--line-d);border-bottom:1px solid var(--line-d);}
.tstrip .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 38px;padding:20px 0;}
.tstrip .ti{display:flex;align-items:center;gap:11px;color:#fff;}
.tstrip .ti svg{width:23px;height:23px;color:var(--gold);flex:none;}
.tstrip .ti span{font-family:'Archivo';font-weight:700;text-transform:uppercase;font-size:13px;letter-spacing:.06em;}

/* ===== TRANSFORMATION ===== */
.transform{background:var(--cream);}
.ba-wrap{display:grid;grid-template-columns:1fr 1fr;border-radius:var(--radius);overflow:hidden;box-shadow:0 18px 44px rgba(0,0,0,.18);position:relative;max-width:980px;margin:0 auto;}
.ba-pane{position:relative;}
.ba-pane img{width:100%;height:clamp(250px,33vw,380px);object-fit:cover;}
.ba-pane.before{border-right:4px solid var(--gold);}
.ba-pane::after{content:"";position:absolute;inset:auto 0 0 0;height:88px;background:linear-gradient(to top,rgba(10,11,13,.7),transparent);}
.ba-tag{position:absolute;bottom:16px;z-index:2;font-family:'Archivo';font-weight:800;text-transform:uppercase;letter-spacing:.1em;font-size:13px;color:#fff;padding:7px 15px;border-radius:5px;line-height:1;}
.ba-pane.before .ba-tag{left:16px;background:rgba(10,11,13,.85);}
.ba-pane.after .ba-tag{right:16px;background:var(--gold);color:#1b1c17;}
.ba-arrow{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3;width:56px;height:56px;border-radius:50%;background:var(--gold);border:3px solid var(--cream);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.4);}
.ba-arrow svg{width:26px;height:26px;color:#1b1c17;}
.transform-cta{text-align:center;margin-top:34px;}

/* ===== WHY MONUMENT (dark credentials) ===== */
.why{background:var(--ink);}
.why-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;}
.why-item{text-align:center;padding:10px 18px;}
.why-item + .why-item{border-left:1px solid var(--line-d);}
.why-ic{width:62px;height:62px;border-radius:50%;border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;background:radial-gradient(circle at 50% 30%,rgba(194,160,90,.16),transparent 70%);}
.why-ic svg{width:28px;height:28px;color:var(--gold);}
.why-item h3{font-size:14.5px;text-transform:uppercase;color:#fff;line-height:1.18;min-height:36px;}
.why-item p{margin-top:10px;font-size:13px;color:var(--muted);line-height:1.5;}

/* ===== SERVICES (light) ===== */
.services{background:var(--cream);}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.svc-card{background:#fff;border:1px solid var(--line-l);border-radius:var(--radius);padding:26px;display:flex;gap:17px;align-items:flex-start;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;}
.svc-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(0,0,0,.1);border-color:rgba(194,160,90,.4);}
.svc-card .s-ic{width:52px;height:52px;border-radius:12px;background:var(--ink);display:flex;align-items:center;justify-content:center;flex:none;}
.svc-card .s-ic svg{width:25px;height:25px;color:var(--gold);}
.svc-card h3{font-size:17px;text-transform:uppercase;color:var(--ink);}
.svc-card p{margin-top:6px;font-size:14px;color:var(--slate);line-height:1.45;}
.svc-card.cta-card{background:var(--ink);border-color:var(--ink);}
.svc-card.cta-card .s-ic{background:rgba(194,160,90,.16);}
.svc-card.cta-card h3{color:#fff;} .svc-card.cta-card p a{color:var(--gold);font-weight:700;}
.services .transform-cta{margin-top:36px;}

/* ===== OFFER BAND ===== */
.offer{background:linear-gradient(120deg,var(--gold-dk),var(--gold) 55%,var(--gold-lt));position:relative;overflow:hidden;}
.offer .wrap{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding:clamp(34px,4vw,52px) 0;position:relative;z-index:2;}
.offer-big{display:flex;align-items:center;gap:22px;}
.offer-pct{font-family:'Archivo';font-weight:800;font-size:clamp(56px,8vw,92px);color:#1b1c17;line-height:.9;letter-spacing:-.02em;}
.offer-copy h2{font-size:clamp(24px,3vw,34px);text-transform:uppercase;color:#1b1c17;}
.offer-copy p{font-weight:600;color:#3a3322;margin-top:6px;font-size:15.5px;letter-spacing:.04em;text-transform:uppercase;}
.offer .btn-dark{background:var(--ink);color:#fff;}
.offer .btn-dark:hover{background:#000;transform:translateY(-2px);}
.offer-peaks{position:absolute;right:-30px;bottom:-50px;width:360px;color:#1b1c17;opacity:.08;z-index:1;}

/* ===== CTA BAND ===== */
.ctaband{background:var(--ink);position:relative;}
.ctaband .wrap{display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;padding:clamp(36px,4vw,56px) 0;}
.ctaband h2{color:#fff;font-size:clamp(26px,3.2vw,38px);text-transform:uppercase;}
.ctaband h2 .hl{color:var(--gold);}
.ctaband p{color:var(--muted);font-weight:500;margin-top:8px;font-size:16.5px;}
.ctaband .ct-actions{display:flex;align-items:center;gap:22px;flex-wrap:wrap;}
.ctaband .ct-phone{display:flex;flex-direction:column;color:#fff;}
.ctaband .ct-phone .l{font-size:11px;text-transform:uppercase;letter-spacing:.14em;font-weight:700;color:var(--muted);}
.ctaband .ct-phone .n{font-family:'Archivo';font-weight:800;font-size:31px;line-height:1.1;color:#fff;}

/* ===== FOOTER ===== */
.ft{background:var(--ink-4);color:#fff;}
.ft-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;padding:clamp(46px,5vw,64px) 0 38px;}
.ft-about p{color:var(--muted);font-size:14.5px;line-height:1.65;max-width:36ch;margin-top:18px;}
.ft-col h4{font-size:13px;text-transform:uppercase;color:var(--gold);letter-spacing:.12em;margin-bottom:18px;}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:11px;}
.ft-col li{display:flex;align-items:center;gap:11px;color:var(--muted);font-size:14.5px;}
.ft-col li svg{width:17px;height:17px;color:var(--gold);flex:none;}
.ft-col a:hover{color:#fff;}
.ft-col a.big{font-family:'Archivo';font-weight:800;font-size:23px;color:#fff;}
.ft-bottom{border-top:1px solid var(--line-d);padding:20px 0;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;}
.ft-bottom p{color:var(--muted-2);font-size:13px;}

/* ===== STICKY MOBILE BAR ===== */
.mbar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;grid-template-columns:1fr 1fr;gap:10px;padding:10px 14px;background:rgba(18,20,22,.97);backdrop-filter:blur(8px);border-top:1px solid var(--gold);}
.mbar .btn{width:100%;padding:14px;font-size:14.5px;}
.mbar .btn-line{background:transparent;border-color:var(--gold);color:var(--gold-lt);}

/* ===== RESPONSIVE ===== */
@media (max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:34px;}
  .hero-copy{max-width:640px;}
  .hero-sub{max-width:none;}
  .why-grid{grid-template-columns:repeat(2,1fr);gap:22px 10px;}
  .why-item{padding:14px;}
  .why-item + .why-item{border-left:none;}
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .ft-top{grid-template-columns:1fr 1fr;}
  .ft-about{grid-column:1 / -1;}
}
@media (max-width:760px){
  .topbar .extra{display:none;}
  .hdr-phone{display:none;} .hdr-cta{display:none;} .hdr-call-mini{display:inline-flex;}
  .hdr .wrap{height:70px;}
  .brand-mark svg{width:44px;height:24px;} .bt-1{font-size:17px;letter-spacing:.22em;} .bt-3{display:none;}
  .ctaband .wrap,.offer .wrap{flex-direction:column;align-items:flex-start;}
  body{padding-bottom:78px;}
  .mbar{display:grid;}
}
@media (max-width:480px){
  .row2{grid-template-columns:1fr;}
  .svc-grid{grid-template-columns:1fr;}
  .why-grid{grid-template-columns:1fr;}
  .why-item + .why-item{border-top:1px solid var(--line-d);padding-top:24px;}
  .ba-pane img{height:200px;}
  .offer-big{flex-direction:column;align-items:flex-start;gap:8px;}
  .ba-arrow{width:44px;height:44px;} .ba-arrow svg{width:20px;height:20px;}
}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}*{transition:none !important;}}
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:4px;}

/* --- WordPress integration --- */
.screen-reader-shortcut{position:absolute;left:-9999px;top:0;z-index:100000;background:var(--gold);color:#1b1c17;padding:10px 16px;font-family:'Archivo',sans-serif;font-weight:800;}
.screen-reader-shortcut:focus{left:6px;top:6px;}
.form-error{background:#fdecec;border:1px solid #e3b0b0;color:#a12626;font-size:13.5px;font-weight:600;padding:11px 14px;border-radius:9px;margin-bottom:14px;}
.brand--img img{max-height:54px;width:auto;display:block;}
@media (max-width:760px){.brand--img img{max-height:42px;}}
.admin-bar .hdr{top:32px;}
@media (max-width:782px){.admin-bar .hdr{top:46px;}}

/* ===== BEFORE / AFTER CAROUSEL ===== */
.gallery{background:var(--ink);}
.gallery .sec-head h2{color:#fff;}
.gallery .eyebrow{color:var(--gold);}
.gallery .sec-head p{color:var(--muted);}
.car{position:relative;}
.car-viewport{position:relative;}
.car-track{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;padding:4px;scrollbar-width:none;}
.car-track::-webkit-scrollbar{display:none;}
.car-slide{flex:0 0 auto;width:min(600px,84%);scroll-snap-align:start;}
.gal-card{background:var(--ink-2);border:1px solid var(--line-d);border-radius:var(--radius);overflow:hidden;height:100%;}
.gal-pair{display:grid;grid-template-columns:1fr 1fr;}
.gal-pair.single{grid-template-columns:1fr;}
.gal-pair > div{position:relative;background:var(--ink-3);aspect-ratio:4 / 3;overflow:hidden;}
.gal-pair .b{border-right:3px solid var(--gold);}
.gal-pair img{width:100%;height:100%;object-fit:cover;display:block;}
.gal-tag{position:absolute;bottom:10px;font-family:'Archivo',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:11px;padding:5px 11px;border-radius:5px;line-height:1;color:#fff;z-index:2;}
.gal-tag.before{left:10px;background:rgba(10,11,13,.85);}
.gal-tag.after{right:10px;background:var(--gold);color:#1b1c17;}
.gal-cap{padding:15px 18px;color:#fff;font-weight:600;font-size:14.5px;display:flex;align-items:center;gap:10px;min-height:20px;}
.gal-cap svg{width:22px;height:11px;color:var(--gold);flex:none;}
.car-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:6;width:50px;height:50px;border-radius:50%;background:var(--gold);color:#1b1c17;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(0,0,0,.45);transition:background .15s ease,opacity .15s ease;}
.car-btn:hover{background:var(--gold-lt);}
.car-btn:disabled{opacity:.3;cursor:default;}
.car-btn svg{width:24px;height:24px;}
.car-prev{left:8px;}
.car-next{right:8px;}
.car-dots{display:flex;justify-content:center;flex-wrap:wrap;gap:9px;margin-top:24px;}
.car-dot{width:9px;height:9px;border-radius:50%;border:none;padding:0;background:rgba(255,255,255,.25);cursor:pointer;transition:background .15s ease,transform .15s ease;}
.car-dot.is-active{background:var(--gold);transform:scale(1.3);}
.gallery .transform-cta{margin-top:34px;}
@media (max-width:600px){.car-btn{display:none;}.car-slide{width:88%;}}

/* ===== VIDEO CAROUSEL ===== */
.videos{background:var(--ink);}
.vid-frame{position:relative;aspect-ratio:16 / 9;background:#000;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-d);}
.vid-frame video,.vid-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;}
.vid-frame video{object-fit:cover;}
