/*
Theme Name: AP Clone Theme
Theme URI: https://amateruphotographer.com
Description: Magazine theme matching Amateur Photographer layout.
Author: Custom Build
Version: 10.0.0
License: Private
Text Domain: ap-clone
*/

/* === VARIABLES === */
:root {
    --purple: #583692;
    --purple-light: #6a42a8;
    --dark: #1a1a1a;
    --text: #333;
    --text-light: #666;
    --text-muted: #999;
    --bg: #eef0f3;
    --white: #fff;
    --border: #ddd;
    --border-light: #eee;
    --stars: #f5c518;
    --font-h: 'Playfair Display', Georgia, serif;
    --font-b: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --max-w: 1200px;
    --gap: 28px;
}

/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--dark);text-decoration:none;transition:color .2s}
a:hover{color:var(--purple)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
.wrapper{max-width:var(--max-w);margin:0 auto;padding:0 20px}

/* =========================================
   HEADER
   ========================================= */
#site-header{background:var(--white);padding:14px 0;border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;gap:16px}

/* Logo */
.site-logo{flex-shrink:0;display:block}
.site-logo img{height:80px;width:auto}
.site-logo .custom-logo{height:80px;width:auto}

/* Search */
.header-search{display:flex;align-items:center;margin-left:16px}
.header-search__input{
    width:160px;padding:8px 12px;border:2px solid var(--border);border-right:none;
    font-size:13px;font-family:var(--font-b);outline:none;background:#fff;
    transition:border-color .2s;
}
.header-search__input:focus{border-color:var(--purple)}
.header-search__btn{
    padding:8px 12px;background:var(--purple);border:2px solid var(--purple);
    cursor:pointer;display:flex;align-items:center;transition:background .2s;
}
.header-search__btn:hover{background:var(--purple-light)}

/* Header Buttons */
.header-actions{display:flex;align-items:center;gap:8px}
.header-btn{
    display:inline-flex;align-items:center;gap:5px;
    padding:7px 16px;font-size:13px;font-weight:500;font-family:var(--font-b);
    border:1px solid #444;color:var(--dark);background:var(--white);
    transition:all .15s;white-space:nowrap;cursor:pointer;
}
.header-btn:hover{background:#f0f0f0;color:var(--dark)}
.header-btn--follow .caret{font-size:10px;opacity:.6}

/* Social Dropdown */
.header-dropdown{position:relative}
.header-dropdown__menu{
    display:none;position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);
    background:var(--white);border:1px solid var(--border);border-radius:8px;
    padding:12px;box-shadow:0 6px 20px rgba(0,0,0,.12);z-index:999;
    gap:8px;flex-direction:row;
}
.header-dropdown:hover .header-dropdown__menu{display:flex}
.soc{
    display:inline-flex;align-items:center;justify-content:center;
    width:34px;height:34px;border-radius:50%;color:#fff;transition:transform .2s;
}
.soc:hover{transform:scale(1.15);color:#fff}
.soc--fb{background:#1877f2}.soc--ig{background:#e4405f}.soc--tt{background:#010101}
.soc--x{background:#1a1a1a}.soc--yt{background:#f00}

/* Mobile */
.mobile-menu-btn{display:none;background:none;border:none;cursor:pointer;padding:6px}

/* Header Badges (right side) */
.header-badges{margin-left:auto;flex-shrink:0;display:flex;align-items:center;gap:6px}
.header-badge{display:flex;align-items:center;flex-shrink:0}
.header-badge img{height:36px;width:auto;transition:opacity .2s;border-radius:4px}
.header-badge:hover img{opacity:.85}

/* =========================================
   NAVIGATION
   ========================================= */
#main-nav{background:var(--purple);position:sticky;top:0;z-index:100}
.nav-inner{display:flex;align-items:center;justify-content:center}
#main-nav .menu{display:flex;align-items:center}
#main-nav .menu>li{position:relative}
#main-nav .menu>li>a{
    display:block;padding:11px 17px;color:#fff;font-size:14px;font-weight:500;
    transition:background .2s;
}
#main-nav .menu>li>a:hover,
#main-nav .menu>li.current-menu-item>a{background:rgba(255,255,255,.14);color:#fff}
#main-nav .menu>li+li>a{border-left:1px solid rgba(255,255,255,.2)}
/* Submenu arrow */
#main-nav .menu>li.menu-item-has-children>a::after{
    content:'';display:inline-block;width:0;height:0;margin-left:6px;vertical-align:middle;
    border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid #fff;
}
/* Submenu */
#main-nav .sub-menu{
    display:none;position:absolute;top:100%;left:0;background:var(--purple);
    min-width:240px;z-index:200;box-shadow:0 4px 12px rgba(0,0,0,.25);
}
#main-nav .menu>li:hover .sub-menu{display:block}
#main-nav .sub-menu li a{
    display:block;padding:10px 20px;color:#fff;font-size:13px;
    border-bottom:1px solid rgba(255,255,255,.08);transition:background .2s;
}
#main-nav .sub-menu li a:hover{background:rgba(255,255,255,.1);color:#fff}
#main-nav .sub-menu li:last-child a{border-bottom:none}

/* =========================================
   TRENDING BAR
   ========================================= */
#trending-bar{background:var(--white);border-bottom:1px solid var(--border);padding:7px 0;overflow:hidden}
.trending-inner{display:flex;align-items:center;gap:14px}
.trending-label{font-size:13px;font-weight:700;color:var(--purple);white-space:nowrap}
.trending-links{display:flex;gap:20px;overflow:hidden;white-space:nowrap}
.trending-links a{font-size:13px;color:var(--text);transition:color .2s}
.trending-links a:hover{color:var(--purple)}

/* =========================================
   MAIN CONTENT AREA
   ========================================= */
#site-content{background:var(--white);padding:0}
#site-content>.wrapper{padding-top:10px;padding-bottom:40px}

/* =========================================
   HOMEPAGE SECTIONS
   ========================================= */
/* Section Heading — centered, Playfair */
.sec-title{
    font-family:var(--font-h);font-size:30px;font-weight:700;
    text-align:center;margin:45px 0 28px;color:var(--dark);
}

/* 3-col grid */
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}

/* Card */
.card{display:flex;flex-direction:column}
.card-thumb{width:100%;aspect-ratio:16/10;object-fit:cover;background:#e0e0e0}
.card-date{font-size:13px;color:var(--text-muted);margin-top:10px}
.card-title{font-family:var(--font-b);font-size:17px;font-weight:700;line-height:1.35;margin-top:5px;color:var(--dark)}
.card-title a{color:var(--dark)}
.card-title a:hover{color:var(--purple)}
.card-excerpt{font-size:14px;line-height:1.5;color:var(--text-light);margin-top:6px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-author{font-size:13px;color:var(--text-muted);margin-top:8px;font-style:italic}
.card-stars{color:var(--stars);font-size:14px;margin-top:3px;letter-spacing:2px}

/* More Button */
.more-wrap{text-align:center;margin:16px 0 40px}
.more-link{
    display:inline-block;padding:9px 26px;border:1px solid var(--dark);color:var(--dark);
    font-size:14px;font-weight:500;transition:all .2s;background:var(--white);
}
.more-link:hover{background:var(--dark);color:var(--white)}

/* Hero Slider */
.hero-slider{position:relative;width:100%;aspect-ratio:16/7;overflow:hidden;margin:35px 0 45px}
.hero-slides{position:relative;width:100%;height:100%}
.hero-slide{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;transition:opacity .6s ease;pointer-events:none}
.hero-slide.active{opacity:1;pointer-events:auto;position:relative}
.hero-slide-img{width:100%;height:100%;object-fit:cover}
.hero-overlay{
    position:absolute;bottom:0;left:0;right:0;padding:28px 36px;
    background:linear-gradient(transparent,rgba(0,0,0,.72));color:#fff;
}
.hero-overlay .card-date{color:rgba(255,255,255,.8)}
.hero-overlay .card-title{color:#fff;font-size:26px;font-family:var(--font-h);line-height:1.2}
.hero-overlay .card-title a{color:#fff}
.hero-overlay .card-excerpt{color:rgba(255,255,255,.9);margin-top:6px}
.hero-overlay .card-stars{margin-top:5px}
.hero-nav{position:absolute;top:50%;right:16px;transform:translateY(-50%);display:flex;gap:6px;z-index:5}
.hero-nav button{
    width:40px;height:40px;border-radius:50%;background:rgba(0,0,0,.5);border:none;
    color:#fff;font-size:20px;cursor:pointer;transition:background .2s;line-height:1;
}
.hero-nav button:hover{background:rgba(0,0,0,.8)}

/* Triple Section (Opinion / Second-hand / Deals) */
.triple{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);margin:45px 0 35px}
.triple-col h2{font-family:var(--font-h);font-size:24px;font-weight:700;margin-bottom:18px;color:var(--dark)}
.lcard{display:flex;gap:14px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-light)}
.lcard:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}
.lcard-img{width:130px;min-width:130px;height:90px;object-fit:cover;background:#e0e0e0;flex-shrink:0}
.lcard-body{flex:1;min-width:0}
.lcard-body .card-date{margin-top:0;font-size:12px}
.lcard-body .card-title{font-size:14px;margin-top:3px;line-height:1.3}
.lcard-body .card-author{font-size:12px;margin-top:5px}
.lcard-img--empty{background:#e0e0e0}
.triple-more{display:inline-block;font-size:13px;color:var(--purple);font-weight:500;margin-top:8px}
.triple-more:hover{text-decoration:underline}

/* =========================================
   SINGLE POST LAYOUT (TOC left + Content)
   ========================================= */
/* Old layout fallback */
.content-wrap{display:flex;gap:var(--gap)}
.content-wrap main{flex:1;min-width:0}
.content-wrap #aside{width:300px;flex-shrink:0}

/* New single layout: TOC left + content right */
.single-layout{display:flex!important;flex-wrap:nowrap!important;gap:0;position:relative;align-items:flex-start}
.single-layout.has-toc .toc-sidebar{display:block}

.toc-sidebar{width:260px;min-width:260px;max-width:260px;flex-shrink:0;padding-right:20px;border-right:1px solid var(--border-light)}
.toc-excerpt{font-size:14px;color:var(--text-light);line-height:1.5;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}
.toc{position:sticky;top:80px;max-height:calc(100vh - 100px);overflow-y:auto;padding:0}
.toc ul{list-style:none;padding:0;margin:0}
.toc ul li{padding:0;border-bottom:1px solid var(--border-light)}
.toc ul li a{
    display:block;padding:10px 14px 10px 0;font-size:13px;font-weight:500;
    color:var(--text);line-height:1.35;transition:color .2s;
}
.toc ul li a:hover{color:var(--purple)}
.toc ul li a.active{color:var(--purple);font-weight:700}

.single-layout > main,
.single-layout > #main{flex:1 1 0%;min-width:0;padding-left:28px;overflow:hidden}

/* Single Header */
.single-head{margin-bottom:22px}
.crumbs{font-size:13px;color:var(--text-muted);margin-bottom:14px}
.crumbs a{color:var(--purple);font-weight:400}
.crumbs a:hover{text-decoration:underline}
.crumbs span{color:var(--text-muted)}
.single-head h1{font-family:var(--font-h);font-size:36px;font-weight:700;line-height:1.15;color:var(--dark);margin-bottom:16px}

/* Author Meta */
.post-meta{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--text-muted);padding-bottom:16px;border-bottom:1px solid var(--border)}
.meta-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}
.meta-info{display:flex;flex-direction:column;gap:1px}
.meta-info .author-link{font-weight:600;color:var(--purple);font-size:14px;text-decoration:none}
.meta-info .author-link:hover{text-decoration:underline}
.meta-info .meta-date{font-size:13px;color:var(--text-muted)}

/* Featured Image */
.feat-img{margin-bottom:24px}
.feat-img img{width:100%}
.feat-img figcaption{font-size:13px;color:var(--text-muted);margin-top:8px;font-style:italic}

/* Entry Content */
.entry-content{font-size:17px;line-height:1.75;color:var(--text);overflow:hidden;overflow-wrap:break-word;word-wrap:break-word;word-break:break-word}
.entry-content p{margin-bottom:1.15em}
.entry-content h2{font-family:var(--font-h);font-size:25px;font-weight:700;margin:1.5em 0 .6em;color:var(--dark);padding-bottom:6px;border-bottom:1px solid var(--border-light);background:none!important;width:auto!important;max-width:100%!important;position:static!important;left:auto!important;right:auto!important;padding-left:0!important;padding-right:0!important;margin-left:0!important;margin-right:0!important;transform:none!important}
.entry-content h3{font-family:var(--font-h);font-size:21px;font-weight:700;margin:1.3em 0 .5em;color:var(--dark)}
.entry-content h4{font-size:18px;font-weight:700;margin:1.1em 0 .4em;color:var(--dark)}
.entry-content img{margin:1em 0;max-width:100%!important;height:auto!important;width:auto}
.entry-content figure{margin:1.4em 0;max-width:100%!important;overflow:hidden}
.entry-content figcaption{font-size:13px;color:var(--text-muted);margin-top:6px;font-style:italic}
.entry-content blockquote{border-left:4px solid var(--purple);padding:14px 20px;margin:1.4em 0;background:#f9f9f9;font-style:italic;max-width:100%!important}
.entry-content ul,.entry-content ol{margin:1em 0;padding-left:1.5em}
.entry-content ul{list-style:disc}
.entry-content ol{list-style:decimal}
.entry-content li{margin-bottom:.35em}
.entry-content a{color:var(--purple);text-decoration:underline}
.entry-content a:hover{color:var(--purple-light)}
/* Constrain ALL child elements — prevent imported content overflow */
.entry-content *{max-width:100%!important;box-sizing:border-box}
.entry-content div,.entry-content section,.entry-content aside,.entry-content article{width:auto!important;position:static!important;left:auto!important;right:auto!important;margin-left:0!important;margin-right:0!important;float:none!important;transform:none!important}
.entry-content table{width:100%!important;border-collapse:collapse;margin:1em 0;overflow-x:auto;display:block}
.entry-content iframe,.entry-content video,.entry-content embed,.entry-content object{max-width:100%!important;width:100%!important}
.entry-content pre,.entry-content code{overflow-x:auto;max-width:100%}
/* Reset WordPress block widths */
.entry-content .wp-block-image,.entry-content .wp-block-embed{max-width:100%!important;margin-left:0!important;margin-right:0!important}
.entry-content .alignfull,.entry-content .alignwide{max-width:100%!important;width:100%!important;margin-left:0!important;margin-right:0!important}

/* Verdict */
.verdict{background:#0b0d0f;color:#fff;padding:26px 28px;margin:0 0 24px}
.verdict-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.verdict h3{font-family:var(--font-h);font-size:20px;margin:0}
.verdict-score{font-size:34px;font-weight:700;color:#e03034}

/* Author Box */
.auth-box{display:flex;gap:18px;padding:22px;background:#f8f8f8;border:1px solid var(--border);margin:32px 0}
.auth-box img{width:72px;height:72px;border-radius:50%;object-fit:cover;flex-shrink:0}
.auth-box-info h3{font-size:15px;font-weight:700;margin-bottom:4px;color:var(--dark)}
.auth-box-info p{font-size:13px;color:var(--text-light);line-height:1.5}

/* Related */
.related{margin-top:36px;padding-top:28px;border-top:1px solid var(--border)}
.related h2{font-family:var(--font-h);font-size:22px;font-weight:700;margin-bottom:20px;color:var(--dark)}

/* =========================================
   SIDEBAR
   ========================================= */
#aside{padding-top:8px}
#aside .widget{margin-bottom:28px}
#aside .widget-title{font-family:var(--font-b);font-size:16px;font-weight:700;margin-bottom:12px;color:var(--dark);padding-bottom:8px;border-bottom:2px solid var(--purple)}
#aside ul li{padding:7px 0;border-bottom:1px solid var(--border-light);font-size:14px}
#aside ul li a{color:var(--text)}
#aside ul li a:hover{color:var(--purple)}

/* =========================================
   CATEGORY / ARCHIVE
   ========================================= */
.page-head h1{font-family:var(--font-h);font-size:30px;font-weight:700;margin-bottom:28px;color:var(--dark)}

/* =========================================
   FOOTER
   ========================================= */
#site-footer{background:#000;color:rgba(255,255,255,.55);padding:50px 0 35px}
.footer-inner{display:flex;gap:80px;flex-wrap:wrap}
.footer-col{min-width:180px}
.footer-col h3{font-size:14px;font-weight:600;color:#c9a96e;margin-bottom:16px;text-transform:uppercase;letter-spacing:.5px}
.footer-col ul li{padding:6px 0}
.footer-col ul li a{color:rgba(100,160,200,.8);font-size:13px;transition:color .2s;text-decoration:none}
.footer-col ul li a:hover{color:#fff}
.footer-col--right{margin-left:auto;text-align:right}
.footer-kelsey-logo{margin-bottom:18px}
.footer-address{font-size:12px;color:rgba(255,255,255,.4);margin-bottom:10px;line-height:1.6}
.footer-copyright{font-size:12px;color:rgba(255,255,255,.4);margin-top:6px}
.footer-copyright a{color:rgba(100,160,200,.7)}
.footer-copyright a:hover{color:#fff}

/* =========================================
   PAGINATION
   ========================================= */
.pagination{display:flex;justify-content:center;gap:6px;margin:36px 0;flex-wrap:wrap}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 10px;border:1px solid var(--border);font-size:14px;font-weight:500;transition:all .2s;color:var(--text)}
.pagination a:hover{background:var(--purple);color:#fff;border-color:var(--purple)}
.pagination .current{background:var(--purple);color:#fff;border-color:var(--purple)}

/* =========================================
   NEWSLETTER
   ========================================= */
.newsletter-bar{background:#f5f5f5;padding:36px 0;text-align:center}
.newsletter-bar h3{font-family:var(--font-h);font-size:22px;margin-bottom:6px}
.newsletter-bar p{color:var(--text-light);font-size:14px;margin-bottom:16px}
.newsletter-bar form{display:flex;justify-content:center;gap:0;max-width:480px;margin:0 auto}
.newsletter-bar input[type="email"]{flex:1;padding:10px 14px;border:2px solid var(--border);border-right:none;font-size:14px;font-family:var(--font-b);outline:none}
.newsletter-bar button{padding:10px 22px;background:var(--purple);color:#fff;border:2px solid var(--purple);font-size:14px;font-family:var(--font-b);font-weight:600;cursor:pointer;transition:background .2s}
.newsletter-bar button:hover{background:var(--purple-light)}

/* =========================================
   RESPONSIVE
   ========================================= */
@media(max-width:979px){
    .g3{grid-template-columns:repeat(2,1fr)}
    .triple{grid-template-columns:1fr}
    .content-wrap{flex-direction:column}
    .content-wrap #aside{width:100%}
    .hero-slider{aspect-ratio:16/9}
    .hero-overlay .card-title{font-size:20px}
    .toc-sidebar{display:none!important}
    .single-layout{display:block!important}
    .single-layout > main,
    .single-layout > #main{padding-left:0}
}
@media(max-width:768px){
    .header-actions{display:none}
    .mobile-menu-btn{display:block}
    .header-search__input{width:120px}
    #main-nav .menu{display:none;flex-direction:column;width:100%}
    #main-nav.open .menu{display:flex}
    #main-nav .menu>li+li>a{border-left:none;border-top:1px solid rgba(255,255,255,.1)}
    #main-nav .sub-menu{position:static;box-shadow:none}
    .g3{grid-template-columns:1fr}
    .sec-title{font-size:24px;margin:28px 0 18px}
    .single-head h1{font-size:26px}
    .header-inner{flex-wrap:wrap}
}
@media(max-width:480px){
    .header-search{display:none}
    .lcard-img{width:100px;min-width:100px;height:68px}
    .footer-inner{flex-direction:column;gap:24px}
}

/* =========================================
   UTILITY & MISC
   ========================================= */
.page-head{margin-bottom:28px}
.page-head h1{font-family:var(--font-h);font-size:30px;font-weight:700;color:var(--dark);margin-bottom:8px}
.page-desc{font-size:15px;color:var(--text-light);line-height:1.5;margin-bottom:16px}
.no-posts{text-align:center;padding:40px 0;color:var(--text-muted);font-size:15px}
.card-thumb--empty{width:100%;aspect-ratio:16/10;background:#e0e0e0}

/* Author page header */
.author-header{display:flex;align-items:center;gap:18px;margin-bottom:8px}
.author-header .meta-avatar{width:72px;height:72px}

/* TOC active link */
.toc-link.active{color:var(--purple)!important;font-weight:700;border-right:3px solid var(--purple);padding-right:11px}

/* Comments */
.comments-area{margin-top:36px;padding-top:24px;border-top:1px solid var(--border)}
.comments-title{font-family:var(--font-h);font-size:20px;margin-bottom:16px}
.comment-list{margin:0;padding:0}
.comment-list li{padding:16px 0;border-bottom:1px solid var(--border-light)}
.comment-list .comment-meta{font-size:13px;color:var(--text-muted);margin-bottom:6px}
.comment-list .comment-content{font-size:15px;line-height:1.6}
.comment-form label{display:block;font-size:14px;font-weight:500;margin-bottom:4px}
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form textarea{width:100%;padding:10px 12px;border:1px solid var(--border);font-family:var(--font-b);font-size:14px;margin-bottom:12px}
.comment-form textarea{min-height:120px}
.comment-form .submit{
    padding:10px 24px;background:var(--purple);color:#fff;border:none;
    font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;
}
.comment-form .submit:hover{background:var(--purple-light)}
