/* ═══════════════════════════════════════════════════════════════
   COLEGROVE MEDIA — SERVICE PAGE STYLES
   Shared CSS for all standalone service pages.
   (Brand Videos has these inline for now; new pages reference this file.)
   ═══════════════════════════════════════════════════════════════ */

.bv-section{padding:72px 40px;border-bottom:1px solid var(--border);}

/* ── HERO ── */
.bv-hero{padding:clamp(40px,5vw,80px) clamp(20px,4vw,56px) clamp(48px,6vw,96px);border-bottom:1px solid var(--border);}
.bv-hero-inner{max-width:1480px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:clamp(32px,5vw,64px);align-items:start;}
@media(min-width:980px){
  .bv-hero{min-height:80vh;display:flex;align-items:center;}
  .bv-hero-inner{grid-template-columns:minmax(320px,1fr) 1.5fr;gap:clamp(40px,4vw,80px);align-items:center;width:100%;}
  .bv-hero-inner--text{grid-template-columns:1fr;max-width:900px;}
}
.bv-hero-text{display:flex;flex-direction:column;gap:clamp(20px,2.4vw,28px);}
.bv-h1{font-family:var(--display,var(--sans));font-size:clamp(40px,7vw,88px);line-height:1.04;font-weight:700;letter-spacing:-0.02em;color:var(--white);margin:0;}
.bv-h1 em{font-style:normal;color:var(--teal);font-weight:700;}
.bv-lede{font-size:clamp(15px,1.4vw,18px);line-height:1.6;color:var(--muted);font-weight:300;max-width:540px;margin:0;}
.bv-cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:4px;}

.bv-hero-video{position:relative;border-radius:14px;overflow:hidden;background:var(--bg3);border:1px solid var(--border);box-shadow:0 24px 60px rgba(0,0,0,0.45);aspect-ratio:16/9;}
.bv-hero-video iframe{position:absolute;inset:0;width:100%;height:100%;display:block;border:0;}

/* ── FEATURED WORK ── */
.bv-feat-header{display:flex;align-items:end;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:12px;}
.bv-feat-header .section-eyebrow{margin:0;}
.bv-feat-header a{color:var(--teal);font-size:13px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;display:inline-flex;align-items:center;gap:6px;transition:gap 0.2s;}
.bv-feat-header a:hover{gap:10px;}
.bv-feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
@media(max-width:960px){.bv-feat-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:540px){.bv-feat-grid{grid-template-columns:1fr;}}
.bv-feat{display:block;border-radius:10px;overflow:hidden;background:var(--bg3);border:1px solid var(--border2);position:relative;transition:transform 0.3s cubic-bezier(0.2,0.8,0.2,1),border-color 0.25s,box-shadow 0.3s;}
.bv-feat-thumb{aspect-ratio:16/9;background:var(--bg3);position:relative;overflow:hidden;}
.bv-feat-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.5s cubic-bezier(0.2,0.8,0.2,1);}
.bv-feat-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(11,14,20,0.85) 0%,rgba(11,14,20,0) 55%);transition:background 0.3s;pointer-events:none;}
.bv-feat-meta{position:absolute;bottom:0;left:0;right:0;padding:14px 16px;}
.bv-feat-cat{font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--teal);margin-bottom:4px;}
.bv-feat-title{font-size:15px;font-weight:600;color:var(--white);line-height:1.3;}
.bv-feat:hover{transform:translateY(-3px);border-color:rgba(0,242,166,0.4);box-shadow:0 14px 32px rgba(0,0,0,0.4);}
.bv-feat:hover .bv-feat-thumb img{transform:scale(1.05);}
.bv-feat:hover .bv-feat-thumb::after{background:linear-gradient(to top,rgba(11,14,20,0.92) 0%,rgba(0,242,166,0.08) 100%);}
.bv-feat-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0.85);width:48px;height:48px;border-radius:50%;background:rgba(0,242,166,0.12);border:1.5px solid rgba(0,242,166,0.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 0.25s,transform 0.25s;backdrop-filter:blur(4px);pointer-events:none;z-index:2;}
.bv-feat:hover .bv-feat-play{opacity:1;transform:translate(-50%,-50%) scale(1);}

/* ── PRICING TIERS ── */
.bv-tier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);border-radius:12px;overflow:visible;}
.bv-tier{background:var(--bg2);padding:40px 32px 32px;display:flex;flex-direction:column;gap:0;position:relative;isolation:isolate;}
.bv-tier.featured{background:var(--bg3);}
.bv-tier.featured::before{content:'Most Popular';position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--teal);color:#0d1117;font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:4px 14px;border-radius:0 0 8px 8px;}
.bv-tier::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--border);transition:background 0.3s;}
.bv-tier.featured::after{background:var(--teal);}
.bv-tier-name{font-size:13px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;}
.bv-tier-price{font-size:clamp(32px,3.5vw,44px);font-weight:700;color:var(--white);line-height:1;margin-bottom:4px;}
.bv-tier-sub{font-size:14px;color:var(--muted);font-weight:300;margin-bottom:24px;}
.bv-tier-divider{height:1px;background:var(--border);margin-bottom:24px;}
.bv-tier-features{list-style:none;display:flex;flex-direction:column;gap:10px;flex:1;margin-bottom:28px;}
.bv-tier-features li{font-size:14px;color:var(--muted);display:flex;align-items:flex-start;gap:10px;line-height:1.45;}
.bv-tier-features li::before{content:'';width:16px;height:16px;border-radius:50%;background:rgba(0,242,166,0.1);border:1px solid rgba(0,242,166,0.3);flex-shrink:0;margin-top:1px;background-image:url("data:image/svg+xml,%3Csvg width='8' height='6' viewBox='0 0 8 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 3L3 5L7 1' stroke='%2300f2a6' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;}
.bv-btn{display:block;text-align:center;padding:13px;border-radius:8px;font-size:13px;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;transition:opacity 0.18s,color 0.18s,border-color 0.18s;cursor:pointer;}
.bv-btn-fill{background:var(--teal);color:#0d1117;border:1px solid var(--teal);}
.bv-btn-fill:hover{opacity:0.85;}
.bv-btn-outline{background:transparent;color:var(--muted);border:1px solid var(--border);}
.bv-btn-outline:hover{color:var(--white);border-color:rgba(0,242,166,0.4);}

/* ── PROCESS ── */
.bv-process{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--border);border-radius:12px;overflow:hidden;}
.bv-proc{background:var(--bg2);padding:32px 24px;position:relative;}
.bv-proc-n{font-size:48px;font-weight:700;color:rgba(0,242,166,0.06);position:absolute;top:16px;right:16px;line-height:1;}
.bv-proc-title{font-size:17px;font-weight:700;color:var(--white);margin-bottom:8px;}
.bv-proc-desc{font-size:14px;color:var(--muted);font-weight:300;line-height:1.6;}

/* ── VIDEO MODAL ── */
.bv-modal{position:fixed;inset:0;z-index:600;background:rgba(11,14,20,0.94);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);display:flex;align-items:center;justify-content:center;padding:40px;opacity:0;visibility:hidden;transition:opacity 0.3s,visibility 0.3s;}
.bv-modal.open{opacity:1;visibility:visible;}
.bv-modal-frame{width:min(1200px,92vw);aspect-ratio:16/9;max-height:88vh;background:#000;border-radius:10px;overflow:hidden;box-shadow:0 0 0 1px rgba(0,242,166,0.2),0 24px 80px rgba(0,0,0,0.5);position:relative;transform:scale(0.97);transition:transform 0.3s cubic-bezier(0.22,1,0.36,1);}
.bv-modal.open .bv-modal-frame{transform:scale(1);}
.bv-modal-video{width:100%;height:100%;position:relative;}
.bv-modal-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;}
.bv-modal-close{position:absolute;top:24px;right:24px;width:44px;height:44px;border-radius:50%;background:rgba(11,14,20,0.6);border:1px solid rgba(0,242,166,0.3);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--white);transition:background 0.2s,border-color 0.2s;padding:0;z-index:2;}
.bv-modal-close:hover{background:rgba(0,242,166,0.18);border-color:rgba(0,242,166,0.6);}
@media(max-width:580px){
  .bv-modal{padding:20px;}
  .bv-modal-close{top:16px;right:16px;width:40px;height:40px;}
}
body.bv-modal-open{overflow:hidden;}

/* ── FAQ ── */
.bv-faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--border);}
.bv-faq{border-bottom:1px solid var(--border);}
.bv-faq-q{width:100%;background:none;border:none;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:24px 4px;cursor:pointer;text-align:left;color:var(--white);font-size:17px;font-weight:600;font-family:inherit;line-height:1.35;transition:color 0.18s;}
.bv-faq-q:hover{color:var(--teal);}
.bv-faq-icon{flex-shrink:0;width:32px;height:32px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--teal);transition:transform 0.3s cubic-bezier(0.34,1.4,0.64,1),background 0.18s;}
.bv-faq-q[aria-expanded="true"] .bv-faq-icon{transform:rotate(45deg);background:rgba(0,242,166,0.08);}
.bv-faq-a{max-height:0;overflow:hidden;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1);}
.bv-faq-q[aria-expanded="true"] + .bv-faq-a{max-height:800px;}
.bv-faq-a-inner{padding:0 4px 24px;font-size:15px;color:var(--muted);font-weight:300;line-height:1.65;max-width:760px;}
.bv-faq-a-inner p{margin:0 0 12px;}
.bv-faq-a-inner p:last-child{margin-bottom:0;}

@media(max-width:960px){
  .bv-section{padding-left:24px;padding-right:24px;}
  .bv-tier-grid{grid-template-columns:1fr;}
  .bv-process{grid-template-columns:1fr 1fr;}
}
@media(max-width:580px){
  .bv-process{grid-template-columns:1fr;}
}
