/*
Theme Name: Nick Graalman Video Portfolio
Theme URI: https://nickgraalman.com/
Author: OpenAI
Description: Minimal video-led portfolio theme for Nick Graalman. Keeps standard WordPress pages and WooCommerce shop intact while adding a cinematic one-page homepage.
Version: 1.4
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
Text Domain: ngvp
*/
:root{--bg:#0b0b0b;--panel:rgba(255,255,255,.06);--text:#f5f5f3;--muted:rgba(245,245,243,.76);--line:rgba(255,255,255,.14);--max:1180px;--radius:22px;--shadow:0 20px 80px rgba(0,0,0,.28);--nav-h:84px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;line-height:1.55}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}.ngvp-site-header{position:fixed;top:0;left:0;right:0;z-index:1000;backdrop-filter:blur(12px);background:linear-gradient(to bottom,rgba(0,0,0,.38),rgba(0,0,0,.12))}.ngvp-nav{max-width:var(--max);margin:0 auto;min-height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:18px 24px}.ngvp-brand{font-size:.95rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase}.ngvp-menu{display:flex;gap:28px;align-items:center}.ngvp-menu a{font-size:.92rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.ngvp-menu a:hover,.ngvp-menu a:focus{color:var(--text)}.ngvp-hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}.ngvp-video-wrap,.ngvp-video-wrap video,.ngvp-video-fallback{position:absolute;inset:0;width:100%;height:100%}.ngvp-video-wrap video{object-fit:cover}.ngvp-video-fallback{background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.08),transparent 30%),linear-gradient(135deg,#0d0d0d,#171717 45%,#090909)}.ngvp-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.30),rgba(0,0,0,.52) 55%,rgba(0,0,0,.76))}.ngvp-hero-inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;width:100%;padding:calc(var(--nav-h) + 40px) 24px 72px}.ngvp-kicker{font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.72);margin-bottom:16px}.ngvp-title{max-width:820px;margin:0;font-size:clamp(2.6rem,7vw,6.2rem);line-height:.95;letter-spacing:-.04em}.ngvp-intro{max-width:720px;font-size:clamp(1rem,1.6vw,1.15rem);color:var(--muted);margin-top:24px}.ngvp-cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.ngvp-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:13px 22px;min-height:48px;border:1px solid var(--line);transition:180ms ease}.ngvp-btn:hover{transform:translateY(-1px)}.ngvp-btn-primary{background:rgba(255,255,255,.96);color:#0e0e0e;border-color:transparent}.ngvp-btn-secondary{background:rgba(255,255,255,.03);color:var(--text)}.ngvp-section{scroll-margin-top:calc(var(--nav-h) + 16px);padding:96px 24px}.ngvp-section-inner{max-width:var(--max);margin:0 auto}.ngvp-section-label{text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.56);font-size:.78rem;margin-bottom:12px}.ngvp-section-title{margin:0 0 22px;font-size:clamp(2rem,4vw,3.2rem);letter-spacing:-.03em}.ngvp-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:28px}.ngvp-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}.ngvp-richtext p:first-child{margin-top:0}.ngvp-richtext p:last-child{margin-bottom:0}.ngvp-richtext p,.ngvp-richtext li{color:var(--muted);font-size:1.04rem}.ngvp-richtext a{text-decoration:underline;text-underline-offset:.22em}.ngvp-contact-list{display:grid;gap:14px}.ngvp-contact-item{padding:16px 0;border-bottom:1px solid var(--line)}.ngvp-contact-item:last-child{border-bottom:0;padding-bottom:0}.ngvp-contact-label{display:block;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.52);margin-bottom:7px}.ngvp-footer{padding:28px 24px 44px;color:rgba(255,255,255,.52);font-size:.92rem}.ngvp-footer-inner{max-width:var(--max);margin:0 auto}.ngvp-site-header+.ngvp-section,body:not(.home) .ngvp-section{padding-top:calc(var(--nav-h) + 56px)}.woocommerce .site-main,.woocommerce-page .site-main{max-width:var(--max);margin:0 auto;padding:calc(var(--nav-h) + 56px) 24px 96px}.woocommerce ul.products li.product,.woocommerce-page ul.products li.product{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.woocommerce ul.products li.product .woocommerce-loop-product__title{color:var(--text);font-size:1.05rem}.woocommerce ul.products li.product .price,.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--muted)}.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,.woocommerce #respond input#submit{border-radius:999px!important;background:rgba(255,255,255,.94)!important;color:#0e0e0e!important;border:0!important;padding:13px 20px!important}.woocommerce div.product .woocommerce-tabs .panel,.woocommerce div.product .summary,.woocommerce-cart .cart-collaterals .cart_totals,.woocommerce-checkout .woocommerce-checkout-review-order{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:24px}.woocommerce table.shop_table,.woocommerce form.checkout_coupon,.woocommerce form.login,.woocommerce form.register{border-color:var(--line);border-radius:var(--radius)}.woocommerce input.input-text,.woocommerce textarea,.woocommerce select{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.25);color:var(--text);border-radius:8px;padding:10px 12px}.woocommerce-message,.woocommerce-info,.woocommerce-error{background:rgba(255,255,255,.08);color:var(--text);border-top-color:rgba(255,255,255,.5)}@media(max-width:760px){:root{--nav-h:72px}.ngvp-nav{padding:14px 18px;align-items:flex-start;gap:12px}.ngvp-menu{gap:12px;flex-wrap:wrap;justify-content:flex-end}.ngvp-brand{font-size:.82rem;letter-spacing:.14em}.ngvp-menu a{font-size:.76rem;letter-spacing:.12em}.ngvp-grid{grid-template-columns:1fr}.ngvp-section{padding:78px 18px}.ngvp-hero-inner{padding-left:18px;padding-right:18px}}


/* Cinematic selected-work video grid */
.ngvp-work-section{padding-top:118px;padding-bottom:118px;background:linear-gradient(to bottom,rgba(255,255,255,.018),rgba(255,255,255,0));}
.ngvp-work-intro{max-width:760px;margin:0 0 34px;color:var(--muted)}
.ngvp-video-showcase{display:grid;gap:26px;margin-top:34px}.ngvp-video-tile{position:relative;overflow:hidden;border:1px solid var(--line);background:rgba(255,255,255,.045);border-radius:calc(var(--radius) + 6px);box-shadow:var(--shadow);transition:transform .24s ease,border-color .24s ease,background .24s ease}.ngvp-video-tile:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.07)}.ngvp-video-frame{position:relative;aspect-ratio:16/9;overflow:hidden;background:#050505}.ngvp-video-frame iframe,.ngvp-video-frame video{position:absolute;inset:0;width:100%!important;height:100%!important;border:0;object-fit:cover}.ngvp-video-frame iframe{pointer-events:none}.ngvp-video-featured{border-radius:32px}.ngvp-video-featured .ngvp-video-frame{aspect-ratio:16/8.2}.ngvp-video-featured:after{content:"Featured";position:absolute;left:22px;top:18px;z-index:2;padding:7px 11px;border-radius:999px;background:rgba(0,0,0,.48);backdrop-filter:blur(10px);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.84);border:1px solid rgba(255,255,255,.16)}.ngvp-video-title{position:absolute;left:22px;right:22px;bottom:18px;z-index:2;margin:0;font-size:clamp(1.25rem,2vw,2rem);letter-spacing:-.03em;text-shadow:0 2px 20px rgba(0,0,0,.8)}.ngvp-video-featured .ngvp-video-frame:after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.06),rgba(0,0,0,.58));pointer-events:none}.ngvp-video-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}.ngvp-video-grid .ngvp-video-tile{border-radius:22px}.ngvp-video-fallback-link{position:absolute;inset:0;display:grid;place-items:center;color:var(--text);text-decoration:underline;text-underline-offset:.25em}.ngvp-video-tile:before{content:"Hover to play";position:absolute;right:14px;bottom:14px;z-index:2;padding:6px 9px;border-radius:999px;background:rgba(0,0,0,.42);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.72);opacity:0;transform:translateY(4px);transition:.2s ease}.ngvp-video-tile:hover:before{opacity:1;transform:translateY(0)}@media(max-width:980px){.ngvp-video-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.ngvp-video-featured .ngvp-video-frame{aspect-ratio:16/9}}@media(max-width:620px){.ngvp-video-grid{grid-template-columns:1fr}.ngvp-video-title{font-size:1.25rem}.ngvp-video-tile:before{display:none}}

/* Legacy collaborations image/text integration */
.ngvp-legacy-strip{margin:34px 0 42px;display:grid;grid-template-columns:.82fr 1.18fr;gap:26px;align-items:start}.ngvp-legacy-copy{background:linear-gradient(145deg,rgba(255,255,255,.075),rgba(255,255,255,.035));border:1px solid var(--line);border-radius:28px;padding:28px;box-shadow:var(--shadow)}.ngvp-legacy-copy h3{margin:0 0 16px;font-size:clamp(1.35rem,2vw,2.1rem);letter-spacing:-.03em}.ngvp-legacy-copy .ngvp-richtext{max-height:620px;overflow:auto;padding-right:8px}.ngvp-legacy-copy .ngvp-richtext::-webkit-scrollbar{width:6px}.ngvp-legacy-copy .ngvp-richtext::-webkit-scrollbar-thumb{background:rgba(255,255,255,.22);border-radius:999px}.ngvp-image-mosaic{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:118px;gap:12px}.ngvp-image-mosaic figure{margin:0;position:relative;overflow:hidden;border-radius:20px;background:#050505;border:1px solid rgba(255,255,255,.1);box-shadow:0 16px 50px rgba(0,0,0,.24)}.ngvp-image-mosaic figure:nth-child(1){grid-column:span 4;grid-row:span 2}.ngvp-image-mosaic figure:nth-child(2){grid-column:span 2;grid-row:span 2}.ngvp-image-mosaic figure:nth-child(3),.ngvp-image-mosaic figure:nth-child(4){grid-column:span 3;grid-row:span 2}.ngvp-image-mosaic figure:nth-child(n+5){grid-column:span 2;grid-row:span 2}.ngvp-image-mosaic img{width:100%;height:100%;object-fit:cover;filter:saturate(.95) contrast(1.02);transition:transform .38s ease,filter .38s ease}.ngvp-image-mosaic figure:hover img{transform:scale(1.04);filter:saturate(1.06) contrast(1.04)}.ngvp-image-mosaic figcaption{position:absolute;left:0;right:0;bottom:0;padding:36px 14px 12px;background:linear-gradient(to top,rgba(0,0,0,.7),rgba(0,0,0,0));font-size:.78rem;color:rgba(255,255,255,.78);opacity:0;transition:.22s ease}.ngvp-image-mosaic figure:hover figcaption{opacity:1}@media(max-width:900px){.ngvp-legacy-strip{grid-template-columns:1fr}.ngvp-image-mosaic{grid-auto-rows:96px}}@media(max-width:560px){.ngvp-image-mosaic{display:block}.ngvp-image-mosaic figure{margin-bottom:14px;height:220px}.ngvp-legacy-copy .ngvp-richtext{max-height:none}}


/* v1.4 native editable homepage content */
.ngvp-native-content{padding:110px 24px;background:linear-gradient(to bottom,rgba(255,255,255,.02),rgba(255,255,255,0));}
.ngvp-native-inner{max-width:var(--max);margin:0 auto;}
.ngvp-native-inner > *:first-child{margin-top:0;}
.ngvp-native-inner > *:last-child{margin-bottom:0;}
.ngvp-native-inner h2,.ngvp-native-inner h3{letter-spacing:-.03em;line-height:1.05;}
.ngvp-native-inner h2{font-size:clamp(2rem,4vw,3.4rem);margin:0 0 24px;}
.ngvp-native-inner h3{font-size:clamp(1.4rem,2.5vw,2.1rem);margin:34px 0 14px;}
.ngvp-native-inner p,.ngvp-native-inner li{color:var(--muted);font-size:1.05rem;}
.ngvp-native-inner a{text-decoration:underline;text-underline-offset:.24em;}
.ngvp-native-inner .wp-block-group{margin:70px 0;}
.ngvp-native-inner .wp-block-columns{gap:32px;margin:42px 0;align-items:center!important;}
.ngvp-native-inner .wp-block-image img,.ngvp-native-inner .wp-block-video video,.ngvp-native-inner .wp-block-embed iframe{border-radius:18px;box-shadow:var(--shadow);border:1px solid var(--line);overflow:hidden;}
.ngvp-native-inner .wp-block-embed{margin:28px 0;}
.ngvp-native-inner .wp-block-embed__wrapper{position:relative;aspect-ratio:16/9;overflow:hidden;border-radius:18px;background:#050505;box-shadow:var(--shadow);border:1px solid var(--line);}
.ngvp-native-inner .wp-block-embed__wrapper iframe{position:absolute;inset:0;width:100%!important;height:100%!important;border:0;border-radius:18px;box-shadow:none;}
.ngvp-native-inner .wp-block-gallery{gap:14px;}
.ngvp-native-inner .wp-block-gallery img{border-radius:18px;}
.ngvp-native-inner .ngvp-work-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;margin:28px 0 70px;}
.ngvp-native-inner .ngvp-work-grid .wp-block-embed{margin:0;}
@media(max-width:900px){.ngvp-native-inner .ngvp-work-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.ngvp-native-content{padding:84px 18px;}}
@media(max-width:620px){.ngvp-native-inner .ngvp-work-grid{grid-template-columns:1fr;}.ngvp-native-inner .wp-block-columns{gap:18px;}}
