/*
Theme Name: Dido
Theme URI: https://easycasserole.com
Description: White-label recipe theme inspired by Snacsy
Version: 7.1.0
Author: Dido
Text Domain: dido
*/

/* =============================================
   RESET & BASE
   ============================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f-body);color:var(--c-text);background:var(--c-bg);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-primary);text-decoration:none;transition:color .2s}
a:hover{color:var(--c-primary-dark)}
h1,h2,h3,h4,h5,h6{font-family:var(--f-heading);font-weight:700;line-height:1.3;color:var(--c-text)}
ul,ol{list-style:none}
button,input,textarea,select{font-family:inherit;font-size:inherit;border:none;outline:none}
button{cursor:pointer}

/* Screen reader */
.screen-reader-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.screen-reader-text:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}

/* =============================================
   LAYOUT
   ============================================= */
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.container-narrow{max-width:780px;margin:0 auto;padding:0 20px}

/* =============================================
   BUTTONS
   ============================================= */
.btn{display:inline-block;padding:12px 28px;border-radius:8px;font-weight:600;font-size:.95rem;transition:all .2s;text-align:center}
.btn-primary{background:var(--c-primary);color:#fff}
.btn-primary:hover{background:var(--c-primary-dark);color:#fff}
.btn-outline{background:transparent;color:var(--c-primary);border:2px solid var(--c-primary)}
.btn-outline:hover{background:var(--c-primary);color:#fff}
.btn-lg{padding:16px 36px;font-size:1.05rem}

/* Pills (category tags) */
.pill{display:inline-block;padding:6px 16px;background:var(--c-primary-light);color:var(--c-primary-dark);border-radius:20px;font-size:.85rem;font-weight:500;margin:4px;transition:all .2s}
.pill:hover{background:var(--c-primary);color:#fff}

/* =============================================
   HEADER
   ============================================= */
.site-header{background:var(--c-card);border-bottom:1px solid var(--c-border);position:sticky;top:0;z-index:100}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.site-branding{flex-shrink:0}
.site-branding img{max-height:50px;width:auto}
.site-logo{font-family:var(--f-heading);font-size:1.6rem;font-weight:700;color:var(--c-text)}
.site-logo:hover{color:var(--c-primary)}

/* Nav */
.site-nav{flex:1;display:flex;justify-content:center}
.nav-menu{display:flex;gap:4px;align-items:center}
.nav-menu li{position:relative}
.nav-menu li a{display:block;padding:8px 14px;color:var(--c-text);font-size:.9rem;font-weight:500;border-radius:6px;transition:all .2s}
.nav-menu li a:hover,.nav-menu li.current-menu-item>a{color:var(--c-primary);background:var(--c-primary-light)}

/* Dropdown */
.nav-menu .sub-menu{display:none;position:absolute;top:100%;left:0;background:var(--c-card);border-radius:10px;box-shadow:0 8px 30px rgba(0,0,0,.1);min-width:200px;padding:8px 0;z-index:200}
.nav-menu li:hover>.sub-menu{display:block}
.nav-menu .sub-menu a{padding:10px 20px;font-size:.85rem;border-radius:0}
.nav-menu .sub-menu a:hover{background:var(--c-bg-alt)}

/* Mobile toggle */
.menu-toggle{display:none;flex-direction:column;gap:5px;padding:8px;background:none}
.menu-toggle span{width:24px;height:2px;background:var(--c-text);transition:all .3s;border-radius:2px}

@media(max-width:768px){
    .site-nav{display:none}
    .menu-toggle{display:flex}
}

/* =============================================
   MOBILE OVERLAY
   ============================================= */
.mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999;opacity:0;visibility:hidden;transition:all .3s}
.mobile-overlay.active{opacity:1;visibility:visible}
.mobile-panel{position:fixed;top:0;right:0;width:300px;height:100%;background:var(--c-card);padding:24px;overflow-y:auto;transform:translateX(100%);transition:transform .3s}
.mobile-overlay.active .mobile-panel{transform:translateX(0)}
.mobile-close{font-size:2rem;background:none;color:var(--c-text);position:absolute;top:12px;right:16px}
.mobile-search{margin:40px 0 20px}
.mobile-search form{display:flex;gap:8px}
.mobile-search input{flex:1;padding:10px 14px;border:1px solid var(--c-border);border-radius:8px;background:var(--c-bg)}
.mobile-search button{padding:10px 14px;background:var(--c-primary);color:#fff;border-radius:8px;font-size:1rem}
.mobile-menu li{border-bottom:1px solid var(--c-border)}
.mobile-menu li a{display:block;padding:14px 0;color:var(--c-text);font-weight:500}
.mobile-menu .sub-menu{padding-left:20px}
.mobile-menu .sub-menu a{font-size:.9rem;color:var(--c-text-light);padding:10px 0}

/* =============================================
   HERO SEARCH
   ============================================= */
.hero-search{padding:60px 20px;text-align:center;background:var(--c-bg-alt)}
.hero-title{font-size:2.2rem;margin-bottom:24px;font-weight:700}
.hero-form{display:flex;max-width:560px;margin:0 auto;background:var(--c-card);border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.08);overflow:hidden;border:1px solid var(--c-border)}
.hero-form input{flex:1;padding:16px 20px;border:none;background:transparent;font-size:1rem}
.hero-form button{padding:16px 28px;background:var(--c-primary);color:#fff;font-weight:600;font-size:1rem;transition:background .2s}
.hero-form button:hover{background:var(--c-primary-dark)}

@media(max-width:480px){
    .hero-title{font-size:1.6rem}
    .hero-form{flex-direction:column;border-radius:12px}
    .hero-form input{border-bottom:1px solid var(--c-border)}
}

/* =============================================
   SECTION HEADINGS
   ============================================= */
.section-heading{text-align:center;font-size:1.5rem;margin-bottom:32px;font-weight:700;text-transform:lowercase}
.section-divider{border:none;border-top:1px solid var(--c-border);margin:48px auto;max-width:800px}
.section-more{text-align:center;margin-top:24px}
.section-more a{color:var(--c-primary);font-weight:600;font-size:.95rem}
.section-more a:hover{text-decoration:underline}

/* =============================================
   CATEGORY GRID (Homepage)
   ============================================= */
.home-categories{padding:48px 0}
.cat-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:24px}
.cat-card{display:flex;flex-direction:column;align-items:center;text-decoration:none;transition:transform .2s}
.cat-card:hover{transform:translateY(-4px)}
.cat-card img{width:130px;height:130px;border-radius:50%;object-fit:cover;border:3px solid var(--c-border);transition:border-color .2s}
.cat-card:hover img{border-color:var(--c-primary)}
.cat-placeholder{width:130px;height:130px;border-radius:50%;background:var(--c-primary-light);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:var(--c-primary);font-family:var(--f-heading)}
.cat-label{margin-top:10px;font-size:.9rem;font-weight:600;color:var(--c-text)}

@media(max-width:600px){
    .cat-grid{gap:16px}
    .cat-card img,.cat-placeholder{width:90px;height:90px}
    .cat-label{font-size:.8rem}
}

/* =============================================
   RECIPE GRID (Shared: home, archive, search)
   ============================================= */
.home-recipes,.archive-content,.search-results,.related-posts,.error-popular{padding:40px 0}
.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}
.recipe-grid-sm{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}

.recipe-card-home{position:relative;overflow:hidden;border-radius:12px;background:var(--c-card);transition:transform .2s,box-shadow .2s}
.recipe-card-home:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.1)}
.recipe-card-home a{display:block;text-decoration:none;color:var(--c-text)}
.recipe-card-home img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:12px 12px 0 0}
.recipe-card-home .card-placeholder{width:100%;aspect-ratio:1/1;background:var(--c-bg-alt);display:flex;align-items:center;justify-content:center;font-size:3rem;border-radius:12px 12px 0 0}
.recipe-card-home h3{padding:12px 14px;font-size:.92rem;font-weight:600;line-height:1.4;font-family:var(--f-body)}

/* Badge */
.card-badge{position:absolute;top:10px;left:10px;padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:600;color:#fff}
.badge-recipe{background:var(--c-primary)}
.badge-article{background:var(--c-accent)}

@media(max-width:600px){
    .recipe-grid{grid-template-columns:repeat(2,1fr);gap:12px}
    .recipe-card-home h3{font-size:.82rem;padding:8px 10px}
}

/* =============================================
   BREADCRUMB
   ============================================= */
.breadcrumb{padding:14px 0;background:var(--c-bg-alt);font-size:.85rem;color:var(--c-text-light)}
.breadcrumb a{color:var(--c-text-light)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb .sep{margin:0 8px;color:var(--c-text-muted)}
.breadcrumb .current{color:var(--c-text);font-weight:500}

/* =============================================
   ARCHIVE
   ============================================= */
.archive-header{padding:40px 0 20px;text-align:center}
.archive-title{font-size:2rem;margin-bottom:8px}
.archive-desc{color:var(--c-text-light);max-width:600px;margin:0 auto 12px}
.archive-count{color:var(--c-text-muted);font-size:.9rem}
.archive-hero-img{width:150px;height:150px;border-radius:50%;object-fit:cover;margin:0 auto 20px;border:3px solid var(--c-border)}

/* =============================================
   SEARCH PAGE
   ============================================= */
.search-header{padding:40px 0 24px;text-align:center}
.search-title{font-size:1.8rem;margin-bottom:20px}
.search-count{color:var(--c-text-muted);font-size:.9rem;margin-top:12px}

/* =============================================
   NO RESULTS / SEARCH TIPS
   ============================================= */
.no-results{text-align:center;padding:60px 0}
.no-results h2{font-size:1.6rem;margin-bottom:12px}
.no-results p{color:var(--c-text-light);margin-bottom:24px}
.search-tips{text-align:left;max-width:400px;margin:24px auto;background:var(--c-bg-alt);padding:20px 24px;border-radius:12px}
.search-tips h3{font-size:1rem;margin-bottom:10px}
.search-tips ul{list-style:disc;padding-left:20px}
.search-tips li{color:var(--c-text-light);font-size:.9rem;margin-bottom:4px}
.other-cats,.popular-section{margin-top:40px}
.other-cats h3,.popular-section h3{font-size:1.1rem;margin-bottom:16px}
.cat-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}

/* =============================================
   404
   ============================================= */
.error-page{padding:60px 0}
.error-content{text-align:center;max-width:600px;margin:0 auto}
.error-title{font-size:2rem;margin-bottom:12px}
.error-message{color:var(--c-text-light);margin-bottom:24px;font-size:1.1rem}
.error-actions{display:flex;gap:12px;justify-content:center;margin-top:24px}
.error-cats{margin-top:48px;text-align:center}

/* =============================================
   SINGLE ARTICLE
   ============================================= */
.article-single{padding:32px 0 48px}
.article-header{margin-bottom:32px}
.article-cat{display:inline-block;padding:4px 14px;background:var(--c-primary-light);color:var(--c-primary-dark);border-radius:20px;font-size:.82rem;font-weight:600;margin-bottom:16px}
.article-cat:hover{background:var(--c-primary);color:#fff}
.article-title{font-size:2.2rem;margin-bottom:16px;line-height:1.25}
.article-meta{color:var(--c-text-muted);font-size:.9rem;margin-bottom:16px}
.article-meta .meta-sep{margin:0 8px}

/* Share */
.article-share{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border)}
.share-label{font-size:.85rem;color:var(--c-text-muted);font-weight:500}
.share-buttons{display:flex;gap:8px}
.share-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--c-bg-alt);border:1px solid var(--c-border);font-size:1rem;cursor:pointer;transition:all .2s;color:var(--c-text);text-decoration:none}
.share-btn:hover{background:var(--c-primary-light);border-color:var(--c-primary)}

/* Featured image */
.article-featured-img{margin:24px 0 32px;border-radius:16px;overflow:hidden}
.article-featured-img img{width:100%;border-radius:16px}

/* Article body */
.article-body{font-size:1.05rem;line-height:1.8;color:var(--c-text)}
.article-body p{margin-bottom:1.4em}
.article-body h2{font-size:1.6rem;margin:2em 0 .8em;padding-bottom:8px;border-bottom:2px solid var(--c-primary-light)}
.article-body h3{font-size:1.3rem;margin:1.6em 0 .6em}
.article-body h4{font-size:1.1rem;margin:1.4em 0 .5em}
.article-body ul,.article-body ol{margin:1em 0 1.4em;padding-left:24px}
.article-body ul{list-style:disc}
.article-body ol{list-style:decimal}
.article-body li{margin-bottom:.5em}
.article-body blockquote{margin:1.5em 0;padding:20px 24px;border-left:4px solid var(--c-primary);background:var(--c-bg-alt);border-radius:0 12px 12px 0;font-style:italic;color:var(--c-text-light)}
.article-body img{border-radius:12px;margin:1.5em 0}
.article-body a{color:var(--c-primary);text-decoration:underline}
.article-body a:hover{color:var(--c-primary-dark)}
.article-body pre,.article-body code{background:var(--c-bg-alt);border-radius:6px;font-size:.9rem}
.article-body pre{padding:16px 20px;overflow-x:auto;margin:1.5em 0}
.article-body code{padding:2px 6px}
.article-body table{width:100%;border-collapse:collapse;margin:1.5em 0}
.article-body th,.article-body td{padding:10px 14px;border:1px solid var(--c-border);text-align:left}
.article-body th{background:var(--c-bg-alt);font-weight:600}
.article-body figure{margin:1.5em 0}
.article-body figcaption{text-align:center;font-size:.85rem;color:var(--c-text-muted);margin-top:8px}

/* Tags */
.article-footer{margin-top:32px;padding-top:20px;border-top:1px solid var(--c-border)}
.article-tags{display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.tags-label{font-weight:600;font-size:.9rem;color:var(--c-text-light)}

/* Post nav */
.article-nav{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:40px;padding-top:24px;border-top:1px solid var(--c-border)}
.nav-prev,.nav-next{display:block;padding:16px;background:var(--c-bg-alt);border-radius:12px;transition:all .2s;text-decoration:none;color:var(--c-text)}
.nav-prev:hover,.nav-next:hover{background:var(--c-primary-light)}
.nav-next{text-align:right}
.nav-label{display:block;font-size:.8rem;color:var(--c-text-muted);margin-bottom:4px}
.nav-title{font-weight:600;font-size:.95rem}

@media(max-width:600px){
    .article-title{font-size:1.6rem}
    .article-body{font-size:1rem}
    .article-nav{grid-template-columns:1fr}
    .nav-next{text-align:left}
}

/* =============================================
   PAGE (static pages)
   ============================================= */
.page-single{padding:40px 0 60px}
.page-title{font-size:2.2rem;margin-bottom:24px;text-align:center}
.page-content{font-size:1.05rem;line-height:1.8}
.page-content p{margin-bottom:1.4em}
.page-content h2{font-size:1.6rem;margin:2em 0 .8em}
.page-content h3{font-size:1.3rem;margin:1.6em 0 .6em}
.page-content ul,.page-content ol{margin:1em 0;padding-left:24px}
.page-content ul{list-style:disc}
.page-content ol{list-style:decimal}
.page-content li{margin-bottom:.5em}
.page-content img{border-radius:12px;margin:1.5em 0}
.page-content blockquote{margin:1.5em 0;padding:20px 24px;border-left:4px solid var(--c-primary);background:var(--c-bg-alt);border-radius:0 12px 12px 0}

/* =============================================
   SUBSCRIBE CTA
   ============================================= */
.subscribe-cta{padding:60px 20px;background:var(--c-primary-light);text-align:center}
.subscribe-inner{max-width:500px}
.subscribe-label{text-transform:lowercase;font-weight:700;font-size:1rem;color:var(--c-primary-dark);margin-bottom:8px}
.subscribe-title{font-size:1.8rem;margin-bottom:12px}
.subscribe-text{color:var(--c-text-light);margin-bottom:24px}

/* =============================================
   SOCIAL ICONS (SVG)
   ============================================= */
.social-links{display:flex;gap:12px;align-items:center}
.social-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;color:var(--c-text-light);transition:all .2s;text-decoration:none}
.social-icon:hover{color:var(--c-primary);transform:translateY(-2px)}
.social-icon svg{fill:currentColor}
.footer-social .social-icon{width:32px;height:32px}

/* =============================================
   AUTHOR BYLINE
   ============================================= */
.author-byline{display:flex;align-items:center;gap:12px;margin:16px 0}
.author-photo{width:40px;height:40px;border-radius:50%;object-fit:cover}
.author-name{font-weight:600;font-size:.9rem;color:var(--c-text)}
.author-bio{font-size:.8rem;color:var(--c-text-muted)}

/* =============================================
   FOOTER
   ============================================= */
.site-footer{padding:30px 20px;background:var(--c-card);border-top:1px solid var(--c-border)}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}
.footer-menu{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}
.footer-menu a{color:var(--c-text-light);font-size:.9rem;font-weight:500}
.footer-menu a:hover{color:var(--c-primary)}
.footer-social{display:flex;gap:12px}
.footer-social a{font-size:1.2rem;opacity:.7;transition:opacity .2s}
.footer-social a:hover{opacity:1}
.footer-copy{font-size:.82rem;color:var(--c-text-muted)}

/* =============================================
   PAGINATION
   ============================================= */
.pagination{margin:40px 0;text-align:center}
.pagination ul{display:flex;justify-content:center;gap:6px;flex-wrap:wrap}
.pagination li{list-style:none}
.pagination a,.pagination .current{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:4px 12px;border-radius:8px;font-weight:500;font-size:.9rem;transition:all .2s}
.pagination a{background:var(--c-card);border:1px solid var(--c-border);color:var(--c-text)}
.pagination a:hover{background:var(--c-primary-light);border-color:var(--c-primary);color:var(--c-primary)}
.pagination .current{background:var(--c-primary);color:#fff;border:1px solid var(--c-primary)}

/* =============================================
   BACK TO TOP
   ============================================= */
.back-to-top{position:fixed;bottom:24px;right:24px;width:44px;height:44px;border-radius:50%;background:var(--c-primary);color:#fff;font-size:1.2rem;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s;z-index:50;box-shadow:0 4px 12px rgba(0,0,0,.15);border:none}
.back-to-top.visible{opacity:1;visibility:visible}
.back-to-top:hover{background:var(--c-primary-dark);transform:translateY(-2px)}

/* =============================================
   ENTRY CONTENT (WP default class compatibility)
   ============================================= */
.entry-content .wp-block-image{margin:1.5em 0}
.entry-content .wp-block-image img{border-radius:12px}
.entry-content .aligncenter{text-align:center}
.entry-content .alignleft{float:left;margin-right:1.5em}
.entry-content .alignright{float:right;margin-left:1.5em}
.entry-content .wp-caption{max-width:100%}
.entry-content .wp-caption-text{font-size:.85rem;color:var(--c-text-muted);text-align:center;margin-top:8px}

/* =============================================
   UTILITY CLASSES
   ============================================= */
.text-center{text-align:center}
.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}

/* =============================================
   PRINT
   ============================================= */
@media print{
    .site-header,.mobile-overlay,.subscribe-cta,.site-footer,.back-to-top,
    .article-share,.article-nav,.related-posts,.breadcrumb,.card-badge,.error-actions{display:none!important}
    body{font-size:12pt;color:#000;background:#fff}
    .container,.container-narrow{max-width:100%;padding:0}
    a{color:#000;text-decoration:underline}
    img{max-width:100%}
}
