/*
Theme Name: VCM Bespoke
Theme URI: https://vintagecamera.smoothbyteit.dev
Author: SmoothByteIT
Description: A bespoke, lightweight custom theme for the Vintage Camera Museum.
Version: 1.0.0
Text Domain: vcm-bespoke
*/

/* ========== CSS RESET & BASE ========== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;line-height:1.6;color:#1a1a2e;background:#fff}
img{max-width:100%;height:auto;display:block}
a{color:#c8a97e;text-decoration:none;transition:color .2s}
a:hover{color:#b8944a}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:'Playfair Display',Georgia,serif;line-height:1.2;color:#1a1a2e}

/* ========== TYPOGRAPHY SCALE ========== */
h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:700}
h2{font-size:clamp(1.75rem,4vw,2.75rem);font-weight:700}
h3{font-size:clamp(1.25rem,3vw,1.75rem);font-weight:600}
h4{font-size:clamp(1.1rem,2.5vw,1.35rem);font-weight:600}
p{margin-bottom:1rem}

/* ========== SPACING SYSTEM ========== */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}
.section--dark{background:#1a1a2e;color:#f0f0f0}
.section--dark h2,.section--dark h3,.section--dark h4{color:#fff}
.section--dark p{color:#d0d0d0}
.section--cream{background:#faf8f5}
.section--gold{background:#c8a97e;color:#fff}

/* ========== BUTTONS ========== */
.btn{display:inline-block;padding:.85rem 2rem;border-radius:4px;font-weight:600;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px;transition:all .3s;border:2px solid transparent;cursor:pointer;font-family:inherit}
.btn--primary{background:#c8a97e;color:#fff;border-color:#c8a97e}
.btn--primary:hover{background:#b8944a;border-color:#b8944a;color:#fff}
.btn--outline{background:transparent;color:#fff;border-color:#fff}
.btn--outline:hover{background:#fff;color:#1a1a2e}
.btn--dark{background:#1a1a2e;color:#fff;border-color:#1a1a2e}
.btn--dark:hover{background:#2d2d4e;border-color:#2d2d4e;color:#fff}
.btn--white{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn--white:hover{background:#fff;color:#1a1a2e;border-color:#fff}
.btn--sm{padding:.6rem 1.25rem;font-size:.85rem}
.btn--block{display:block;width:100%;text-align:center}

/* ========== TOP BAR ========== */
.top-bar{background:#1a1a2e;color:#e0e0e0;font-size:.85rem;padding:.5rem 0}
.top-bar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.top-bar a{color:#c8a97e}
.top-bar a:hover{color:#fff}
.top-bar__contact{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap}
.top-bar__social{display:flex;gap:1rem;align-items:center}
.top-bar__social a{font-size:1.1rem}

/* ========== HEADER / NAV ========== */
.site-header{background:#fff;border-bottom:1px solid #eee;position:sticky;top:0;z-index:1000;box-shadow:0 2px 10px rgba(0,0,0,.05)}
.site-header .container{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;padding-bottom:.75rem}
.site-logo{font-family:'Playfair Display',Georgia,serif;font-size:1.5rem;font-weight:700;color:#1a1a2e}
.site-logo span{color:#c8a97e}
.nav-toggle{display:none;background:none;border:none;font-size:1.75rem;cursor:pointer;color:#1a1a2e;padding:.5rem;min-width:44px;min-height:44px;line-height:1}
body.nav-open{overflow:hidden}
.main-nav ul{display:flex;gap:0;align-items:center}
.main-nav a{display:block;padding:.75rem 1rem;color:#1a1a2e;font-weight:500;font-size:.95rem;transition:color .2s}
.main-nav a:hover,.main-nav .current-menu-item a,.main-nav .current_page_item a{color:#c8a97e}

@media(max-width:992px){
.nav-toggle{display:flex;align-items:center;justify-content:center}
.main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-top:1px solid #eee;box-shadow:0 4px 20px rgba(0,0,0,.15);max-height:calc(100vh - 120px);overflow-y:auto;-webkit-overflow-scrolling:touch}
.main-nav.active{display:block}
.main-nav ul{flex-direction:column;padding:0}
.main-nav li{border-bottom:1px solid #f5f5f5}
.main-nav li:last-child{border-bottom:none}
.main-nav a{padding:1rem 1.5rem;font-size:1rem;min-height:48px;display:flex;align-items:center}
.main-nav a:active{background:#faf8f5}
}

/* ========== HERO ========== */
.hero{background:linear-gradient(135deg,#1a1a2e 0%,#2d2d4e 50%,#1a1a2e 100%);color:#fff;padding:6rem 0;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(26,26,46,.75);pointer-events:none;z-index:0}
.hero__content{position:relative;z-index:1;max-width:800px;margin:0 auto}
.hero__brand{font-size:clamp(2.5rem,6vw,4rem);margin-bottom:1rem;font-family:'Playfair Display',Georgia,serif;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.3)}
.hero__brand span{color:#d4b896}
.hero__subtitle{font-size:clamp(1rem,2vw,1.2rem);color:#e8e8e8;margin-bottom:2.5rem;line-height:1.8}
.hero__buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ========== SECTION HEADERS ========== */
.section-header{text-align:center;margin-bottom:3rem}
.section-header__label{color:#c8a97e;font-weight:600;text-transform:uppercase;letter-spacing:2px;font-size:.85rem;margin-bottom:.5rem;display:block}
.section-header__title{margin-bottom:1rem}
.section-header__desc{color:#555;max-width:700px;margin:0 auto;font-size:1.05rem}
.section--dark .section-header__desc{color:#ccc}
.section--dark .section-header__label{color:#d4b896}

/* ========== CARDS GRID ========== */
.cards-grid{display:grid;gap:2rem}
.cards-grid--2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.cards-grid--3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.cards-grid--4{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.cards-grid--6{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}

/* ========== PRICING CARDS ========== */
.pricing-card{background:#fff;border-radius:12px;padding:2.5rem 2rem;text-align:center;border:2px solid #eee;transition:all .3s;position:relative;overflow:hidden}
.pricing-card:hover{border-color:#c8a97e;transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.1)}
.pricing-card--featured{border-color:#c8a97e;transform:scale(1.02)}
.pricing-card--featured::before{content:'POPULAR';position:absolute;top:1rem;right:-2rem;background:#c8a97e;color:#fff;padding:.25rem 3rem;font-size:.75rem;font-weight:700;transform:rotate(45deg);letter-spacing:1px}
.pricing-card__name{font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:#c8a97e;margin-bottom:1rem}
.pricing-card__price{font-size:3rem;font-weight:700;color:#1a1a2e;margin-bottom:.5rem}
.pricing-card__price span{font-size:1.25rem;color:#999}
.pricing-card__features{margin:1.5rem 0 2rem;text-align:left}
.pricing-card__features li{padding:.6rem 0;border-bottom:1px solid #f5f5f5;color:#555;display:flex;align-items:center;gap:.5rem}
.pricing-card__features li::before{content:'✓';color:#c8a97e;font-weight:700}

/* ========== TESTIMONIAL ========== */
.testimonial-card{background:#fff;border-radius:12px;padding:2rem;border:1px solid #eee;transition:box-shadow .3s}
.testimonial-card:hover{box-shadow:0 10px 30px rgba(0,0,0,.08)}
.testimonial-card__text{font-style:italic;color:#444;line-height:1.8;margin-bottom:1.5rem;position:relative;padding-left:1.5rem;border-left:3px solid #c8a97e}
.testimonial-card__author{font-weight:700;color:#1a1a2e}
.testimonial-card__role{color:#c8a97e;font-size:.9rem}

/* ========== STATS ========== */
.stats-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;text-align:center}
.stat-item__number{font-size:clamp(2rem,4vw,3rem);font-weight:700;color:#d4b896;font-family:'Playfair Display',Georgia,serif}
.stat-item__label{color:#e0e0e0;text-transform:uppercase;letter-spacing:2px;font-size:.85rem;margin-top:.25rem}

/* ========== BLOG CARDS ========== */
.blog-card{background:#fff;border-radius:12px;overflow:hidden;border:1px solid #eee;transition:all .3s}
.blog-card:hover{box-shadow:0 10px 30px rgba(0,0,0,.08);transform:translateY(-2px)}
.blog-card__img{height:200px;background:#f5f5f5;overflow:hidden}
.blog-card__img img{width:100%;height:100%;object-fit:cover}
.blog-card__body{padding:1.5rem}
.blog-card__date{color:#c8a97e;font-size:.85rem;font-weight:600;margin-bottom:.5rem}
.blog-card__title{font-size:1.1rem;margin-bottom:.75rem}
.blog-card__title a{color:#1a1a2e}
.blog-card__title a:hover{color:#c8a97e}
.blog-card__excerpt{color:#666;font-size:.95rem}

/* ========== GALLERY GRID ========== */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}
.gallery-grid__item{border-radius:8px;overflow:hidden;aspect-ratio:1;position:relative}
.gallery-grid__item img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.gallery-grid__item:hover img{transform:scale(1.05)}

/* ========== CATEGORY TAGS ========== */
.category-tags{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.category-tag{background:#fff;border:2px solid #eee;border-radius:50px;padding:.75rem 1.75rem;font-weight:500;color:#1a1a2e;transition:all .3s}
.category-tag:hover{border-color:#c8a97e;color:#c8a97e;background:#faf8f5}

/* ========== INSTAGRAM STRIP ========== */
.instagram-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}
.instagram-grid__item{aspect-ratio:1;background:#f5f5f5;border-radius:8px;overflow:hidden}
.instagram-grid__item img{width:100%;height:100%;object-fit:cover}

/* ========== WHY CHOOSE US ========== */
.feature-card{text-align:center;padding:2rem 1.5rem}
.feature-card__icon{width:64px;height:64px;margin:0 auto 1.5rem;background:#c8a97e;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem}
.feature-card__title{margin-bottom:.75rem;font-size:1.15rem}
.feature-card__desc{color:#666;font-size:.95rem;line-height:1.7}

/* ========== CONTACT ========== */
.contact-info{display:grid;gap:1.5rem;margin-bottom:2rem}
.contact-info__item{display:flex;gap:1rem;align-items:flex-start}
.contact-info__icon{width:48px;height:48px;background:#c8a97e;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;flex-shrink:0}
.contact-info__text h4{margin-bottom:.25rem}
.contact-info__text p{color:#666;margin:0}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:.85rem 1rem;border:2px solid #eee;border-radius:8px;font-family:inherit;font-size:1rem;transition:border-color .2s}
.contact-form input:focus,.contact-form textarea:focus{border-color:#c8a97e;outline:none}
.contact-form .form-group{margin-bottom:1.25rem}
.contact-form label{display:block;margin-bottom:.5rem;font-weight:500;color:#1a1a2e}

/* ========== MEMBER BOX ========== */
.member-perk-box{background:linear-gradient(135deg,#c8a97e,#b8944a);color:#fff;border-radius:12px;padding:2rem;margin:2rem 0}
.member-perk-box h3{color:#fff;margin-bottom:1rem}
.member-perk-box a{color:#fff;text-decoration:underline}

/* ========== FOOTER ========== */
.site-footer{background:#1a1a2e;color:#ccc;padding:4rem 0 0}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:3rem;margin-bottom:3rem}
.footer-col h4{color:#fff;margin-bottom:1.25rem;font-size:1.1rem}
.footer-col p,.footer-col li{color:#999;font-size:.95rem;line-height:1.8}
.footer-col a{color:#999;transition:color .2s}
.footer-col a:hover{color:#c8a97e}
.footer-col ul li{margin-bottom:.5rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.5rem 0;text-align:center;color:#666;font-size:.9rem}
.footer-social{display:flex;gap:1rem;margin-top:1rem}
.footer-social a{width:40px;height:40px;border-radius:50%;border:1px solid #444;display:flex;align-items:center;justify-content:center;color:#999;transition:all .2s}
.footer-social a:hover{border-color:#c8a97e;color:#c8a97e;background:rgba(200,169,126,.1)}

/* ========== PAGE HEADER ========== */
.page-header{background:linear-gradient(135deg,#1a1a2e,#2d2d4e);color:#fff;padding:4rem 0;text-align:center;position:relative;background-size:cover;background-position:center;overflow:hidden}
.page-header::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(26,26,46,.8);z-index:0}
.page-header .container{position:relative;z-index:1}
.page-header h1{margin-bottom:.5rem;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.3)}
.page-header p{color:#e0e0e0;font-size:1.1rem}
.breadcrumbs{display:flex;gap:.5rem;justify-content:center;margin-top:1rem;font-size:.9rem;color:#bbb}
.breadcrumbs a{color:#d4b896}

/* ========== WP SPECIFIC ========== */
.entry-content{max-width:800px;margin:0 auto}
.entry-content p{margin-bottom:1.25rem;line-height:1.8;color:#444}
.entry-content h2{margin:2rem 0 1rem}
.entry-content h3{margin:1.75rem 0 .75rem}
.entry-content ul,.entry-content ol{margin:1rem 0 1.5rem 1.5rem}
.entry-content ul{list-style:disc}
.entry-content ol{list-style:decimal}
.entry-content li{margin-bottom:.5rem;color:#555}
.entry-content blockquote{border-left:4px solid #c8a97e;padding:1rem 1.5rem;margin:1.5rem 0;background:#faf8f5;border-radius:0 8px 8px 0}
.alignwide{max-width:1200px;margin-left:auto;margin-right:auto}
.alignfull{max-width:100vw;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%)}

/* ========== PAGINATION ========== */
.pagination{display:flex;gap:.5rem;justify-content:center;margin:3rem 0}
.pagination a,.pagination span{padding:.6rem 1rem;border:1px solid #eee;border-radius:4px;color:#1a1a2e}
.pagination .current{background:#c8a97e;color:#fff;border-color:#c8a97e}

/* ========== UTILITIES ========== */
.text-center{text-align:center}
.text-gold{color:#c8a97e}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.mb-1{margin-bottom:1rem}.mb-2{margin-bottom:2rem}.mb-3{margin-bottom:3rem}
.py-1{padding-top:1rem;padding-bottom:1rem}
.hidden{display:none}

/* ========== PMPRO OVERRIDES ========== */
#pmpro_form .pmpro_btn,
.pmpro_btn{background:#c8a97e!important;border-color:#c8a97e!important;color:#fff!important;border-radius:4px!important;padding:.85rem 2rem!important;font-weight:600!important}
#pmpro_form .pmpro_btn:hover,
.pmpro_btn:hover{background:#b8944a!important;border-color:#b8944a!important}
.pmpro_invoice_wrap{max-width:800px;margin:0 auto}

/* ========== CF7 OVERRIDES ========== */
.wpcf7 input[type="text"],.wpcf7 input[type="email"],.wpcf7 input[type="tel"],.wpcf7 textarea{width:100%;padding:.85rem 1rem;border:2px solid #eee;border-radius:8px;font-family:inherit;font-size:1rem;transition:border-color .2s}
.wpcf7 input:focus,.wpcf7 textarea:focus{border-color:#c8a97e;outline:none}
.wpcf7 input[type="submit"]{background:#c8a97e;color:#fff;border:none;padding:.85rem 2rem;border-radius:4px;font-weight:600;cursor:pointer;font-size:1rem;text-transform:uppercase;letter-spacing:.5px}
.wpcf7 input[type="submit"]:hover{background:#b8944a}

/* ========== RESPONSIVE ========== */

/* --- Tablet (max 992px) --- */
@media(max-width:992px){
.cards-grid--3{grid-template-columns:repeat(2,1fr)}
.cards-grid--4{grid-template-columns:repeat(2,1fr)}
.instagram-grid{grid-template-columns:repeat(2,1fr)}
.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
}

/* --- Small tablet / large phone (max 768px) --- */
@media(max-width:768px){
.section{padding:3rem 0}
.hero{padding:3.5rem 0}
.hero__brand{font-size:2rem}
.hero__subtitle{font-size:.95rem;margin-bottom:1.5rem;padding:0 .5rem}
.hero__buttons{flex-direction:column;align-items:center;gap:.75rem}
.hero__buttons .btn{width:80%;max-width:280px;text-align:center}

.page-header{padding:2.5rem 0}
.page-header h1{font-size:1.75rem}
.page-header p{font-size:.95rem}

.top-bar{font-size:.78rem;padding:.4rem 0}
.top-bar .container{flex-direction:column;text-align:center;gap:.35rem}
.top-bar__contact{justify-content:center;gap:.75rem;flex-wrap:wrap}
.top-bar__social{justify-content:center}

.site-header .container{padding-top:.5rem;padding-bottom:.5rem}
.site-logo{font-size:1.2rem}

.section-header{margin-bottom:2rem}
.section-header__title{font-size:1.5rem}
.section-header__desc{font-size:.95rem;padding:0 .5rem}

.cards-grid--2,.cards-grid--3,.cards-grid--4{grid-template-columns:1fr}
.cards-grid{gap:1.25rem}

.pricing-card{padding:2rem 1.5rem}
.pricing-card__price{font-size:2.5rem}
.pricing-card--featured{transform:none}
.pricing-card--featured::before{top:.75rem;right:-2.25rem;font-size:.65rem;padding:.2rem 2.75rem}

.testimonial-card{padding:1.5rem}
.testimonial-card__text{font-size:.9rem;line-height:1.7;padding-left:1rem}

.stats-strip{grid-template-columns:repeat(2,1fr);gap:1.5rem}
.stat-item__number{font-size:2rem}
.stat-item__label{font-size:.75rem}

.blog-card__img{height:180px}
.blog-card__body{padding:1.25rem}
.blog-card__title{font-size:1rem}

.gallery-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}
.gallery-grid__item{aspect-ratio:1}

.instagram-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}

.category-tags{gap:.6rem}
.category-tag{padding:.6rem 1.25rem;font-size:.9rem}

.feature-card{padding:1.5rem 1rem}
.feature-card__icon{width:52px;height:52px;font-size:1.25rem;margin-bottom:1rem}
.feature-card__title{font-size:1.05rem}
.feature-card__desc{font-size:.9rem}

.footer-grid{grid-template-columns:1fr;gap:2rem}
.footer-col{text-align:center}
.footer-col ul{padding:0}
.footer-social{justify-content:center}
.footer-bottom{font-size:.8rem}

.entry-content{padding:0 .5rem}
.entry-content p{font-size:.95rem}

.contact-info__item{flex-direction:column;align-items:center;text-align:center}

.member-perk-box{padding:1.5rem}

.breadcrumbs{font-size:.8rem;flex-wrap:wrap}

.pagination{flex-wrap:wrap}
.pagination a,.pagination span{padding:.5rem .75rem;font-size:.85rem}

.btn{padding:.75rem 1.5rem;font-size:.85rem}
.btn--block{padding:.75rem 1rem}

#pmpro_form{padding:0 .5rem}
.pmpro_invoice_wrap{padding:0 .5rem}

.wpcf7 input[type="submit"]{width:100%;padding:.85rem}
}

/* --- Phone (max 480px) --- */
@media(max-width:480px){
.container{padding:0 1rem}
.section{padding:2.5rem 0}

.hero{padding:2.5rem 0}
.hero__brand{font-size:1.65rem}
.hero__subtitle{font-size:.88rem;line-height:1.6}
.hero__buttons .btn{width:90%;font-size:.8rem;padding:.7rem 1rem}

.page-header{padding:2rem 0}
.page-header h1{font-size:1.4rem}

.top-bar__contact{flex-direction:column;gap:.25rem}

.site-logo{font-size:1.05rem}

.cards-grid--6{grid-template-columns:repeat(2,1fr)}
.pricing-card{padding:1.5rem 1rem}
.pricing-card__name{font-size:.95rem}
.pricing-card__price{font-size:2rem}
.pricing-card__features li{font-size:.9rem;padding:.5rem 0}

.stats-strip{grid-template-columns:repeat(2,1fr);gap:1rem}
.stat-item__number{font-size:1.65rem}
.stat-item__label{font-size:.7rem;letter-spacing:1px}

.gallery-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}
.gallery-grid__item{border-radius:4px}

.instagram-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}

.blog-card__img{height:150px}
.blog-card__body{padding:1rem}
.blog-card__date{font-size:.78rem}
.blog-card__title{font-size:.95rem}
.blog-card__excerpt{font-size:.85rem}

.testimonial-card__text{font-size:.85rem}
.testimonial-card__author{font-size:.9rem}

.section-header__label{font-size:.75rem;letter-spacing:1.5px}
.section-header__title{font-size:1.3rem}

.feature-card__desc{font-size:.85rem}

.contact-form input,.contact-form textarea,.contact-form select{padding:.75rem .85rem;font-size:.9rem}

.footer-col h4{font-size:1rem}
.footer-col p,.footer-col li{font-size:.88rem}

h1{font-size:1.5rem}
h2{font-size:1.35rem}
h3{font-size:1.1rem}
}
