/*
Theme Name: Jolyti Blogger (Optimized)
Theme URI: https://balconyhaven.com
Author: Isaac Tiaon
Description: Clean two-column blog theme with a calm green palette and optimized CSS structure.
Version: 1.0.1
License: GPLv2 or later
Text Domain: balconyhaven
*/

/* =========================================================
   1) THEME TOKENS
   ========================================================= */
:root{
  --brand-primary:#1F4D2E;
  --brand-on-primary:#FFFFFF;
  --brand-accent-soft:#E6F3EC;

  --nav-surface:#EEF5F0;
  --nav-ink:#1F2D26;
  --nav-ink-hover:#4F8A5B;

  --page-surface:#FAFCFA;
  --text-primary:#1F2D26;
  --text-muted:#66776C;

  --surface-primary:#FFFFFF;
  --surface-secondary:#EEF5F0;

  --border-light:#DCE8E0;
  --border-strong:#C6D9CD;
  --shadow-soft:0 10px 26px rgba(31,45,38,.08);

  --btn-primary-bg:#5C9A6A;
  --btn-primary-text:#FFFFFF;
  --btn-primary-bg-hover:#3F7A4F;
  --btn-primary-text-hover:#FFFFFF;

  --section-head-bg:#EEF5F0;
  --section-head-text:#1F2D26;
  --footer-link-hover:#B7E4C7;

  --radius-sm:10px;
  --radius-md:14px;
  --radius-pill:999px;

  --white-14:rgba(255,255,255,.14);
  --white-12:rgba(255,255,255,.12);

  /* Legacy aliases used by existing theme templates */
  --brand-bg:var(--brand-primary);
  --brand-title:var(--brand-on-primary);
  --brand-tagline:var(--brand-accent-soft);
  --nav-bg:var(--nav-surface);
  --nav-link:var(--nav-ink);
  --nav-link-hover:var(--nav-ink-hover);
  --page-bg:var(--page-surface);
  --page-text:var(--text-primary);
  --card-bg:var(--surface-primary);
  --surface:var(--surface-secondary);
  --border:var(--border-light);
  --shadow:var(--shadow-soft);
  --btn-bg:var(--btn-primary-bg);
  --btn-text:var(--btn-primary-text);
  --btn-hover-bg:var(--btn-primary-bg-hover);
  --btn-hover-text:var(--btn-primary-text-hover);
  --side-head-bg:var(--section-head-bg);
  --side-head-text:var(--section-head-text);
  --radius:var(--radius-md);
  --green:var(--brand-bg);
}

/* =========================================================
   2) BASE
   ========================================================= */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,"Noto Sans","Helvetica Neue",sans-serif;
  background:var(--page-bg);
  color:var(--page-text);
  line-height:1.65;
}
img{display:block;max-width:100%;height:auto}
a{color:var(--nav-link-hover);text-decoration:none}
a:hover{color:var(--btn-hover-bg)}
button,input[type="submit"]{cursor:pointer}
.container{width:min(1100px,92%);margin-inline:auto}
.site-content,.main-col,.entry-content{min-width:0;overflow:visible}

/* Elementor full-width pages */
body.elementor-page .site-content .container,
body.elementor-page .site-content .grid,
body.elementor-page .site-content .main-col{width:100%;max-width:none}

/* Gutenberg wide/full */
.alignfull{width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.alignwide{width:min(1200px,96%);max-width:1200px;margin-inline:auto}

/* =========================================================
   3) TOPBAR
   ========================================================= */
.topbar{background:var(--brand-bg);color:var(--brand-title);font-size:13px}
.topbar-inner{display:flex;gap:16px;align-items:center;justify-content:space-between;padding:10px 0}
.topbar a{color:var(--brand-title)}
.topbar a:hover{color:var(--footer-link-hover)}
.topbar-links,.topbar-icons{display:flex;align-items:center;flex-wrap:wrap}
.topbar-links{gap:14px}
.topbar-icons{gap:10px}
.icon-pill{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-pill);background:var(--white-12);border:1px solid var(--white-14)}

/* =========================================================
   4) HEADER + NAVIGATION
   ========================================================= */
.site-header.site-header--solid{
  background:linear-gradient(to bottom,var(--brand-bg) 0%,var(--brand-bg) 68%,var(--nav-bg) 68%,var(--nav-bg) 100%);
  border-bottom:1px solid var(--border);
}
.site-header.site-header--solid .branding{padding:36px 0 18px;text-align:center}
.site-header .site-title{margin:0;font-size:clamp(40px,4.2vw,56px);line-height:1.05;letter-spacing:.3px}
.site-header .site-title a{color:var(--brand-title)}
.site-header .site-description{margin:10px 0 0;font-size:12px;letter-spacing:1.6px;text-transform:uppercase;color:var(--brand-tagline)}

.main-nav{background:var(--nav-bg);border-block:1px solid var(--border)}
.main-nav .nav-inner{display:flex;align-items:center;justify-content:space-between;gap:14px}
.main-nav .menu,
.main-nav ul.menu{display:flex;align-items:center;flex-wrap:wrap;gap:18px;list-style:none;margin:0;padding:12px 0}
.main-nav a{display:inline-block;padding:8px 12px;color:var(--nav-link)}
.main-nav a:hover,
.main-nav .current-menu-item>a,
.main-nav .current_page_item>a{color:var(--nav-link-hover)}

.nav-search{position:relative;display:flex;align-items:center}
.nav-search-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 10px;border:0;background:transparent;color:var(--nav-link);line-height:1}
.nav-search-btn:hover{color:var(--nav-link-hover)}
.nav-search-btn img{width:18px;height:18px}
.nav-search-panel[hidden]{display:none}
.nav-search-panel:not([hidden]){position:absolute;right:0;top:calc(100% + 10px);z-index:9999;display:block;width:min(320px,80vw);padding:12px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.nav-search-panel input[type="search"]{width:100%;margin:0}
.nav-search-panel .search-submit{margin-top:10px}

/* =========================================================
   5) LAYOUT
   ========================================================= */
.site-content{padding:34px 0 40px}
.grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:26px}
@media (max-width:920px){.grid{grid-template-columns:1fr}}

/* =========================================================
   6) POST CARDS + SINGLE CONTENT
   ========================================================= */
.post-card{display:grid;grid-template-columns:260px minmax(0,1fr);position:relative;overflow:hidden;margin-bottom:22px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.post-thumb{position:relative;z-index:1;min-height:190px;overflow:hidden;background:var(--surface)}
.post-thumb img{width:100%;height:100%;object-fit:cover;object-position:center}
.post-body{position:relative;z-index:1;padding:18px 18px 20px}
.post-title{margin:0 0 8px;font-size:22px;line-height:1.25}
.post-excerpt{margin:0 0 14px;color:var(--text-muted)}
.post-meta{margin:0 0 10px;font-size:12px;color:var(--text-muted)}
.post-content h1,.post-content h2,.post-content h3{margin:18px 0 10px;line-height:1.25}
.post-content p{margin:0 0 14px;color:var(--page-text)}
.post-content a{color:var(--nav-link-hover);text-decoration:underline;text-underline-offset:3px}
.post-content a:hover{color:var(--btn-hover-bg)}
@media (max-width:720px){.post-card{grid-template-columns:1fr}}

/* =========================================================
   7) BUTTONS + FORMS
   ========================================================= */
.btn,.button,.wp-block-button__link,.search-submit,.wpcf7 input.wpcf7-submit,.wpcf7 button.wpcf7-submit{
  display:inline-flex;align-items:center;justify-content:center;padding:12px 20px;border:0;border-radius:var(--radius-sm);background:var(--btn-bg);color:var(--btn-text);font-size:15px;font-weight:600;letter-spacing:.2px;text-decoration:none;transition:background .2s ease,color .2s ease,transform .2s ease;
}
.btn:hover,.button:hover,.wp-block-button__link:hover,.search-submit:hover,.wpcf7 input.wpcf7-submit:hover,.wpcf7 button.wpcf7-submit:hover{background:var(--btn-hover-bg);color:var(--btn-hover-text);transform:translateY(-1px)}
input[type="search"],input[type="text"],input[type="email"]{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface)}

/* =========================================================
   8) WIDGETS + SIDEBAR
   ========================================================= */
.widget{margin-bottom:18px;padding:16px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);color:var(--page-text)}
.widget-title,
.sidebar .widget-title,
.sidebar .widget .wp-block-heading,
.sidebar .widget:is(h1,h2,h3,h4,h5,h6),
.sidebar .widget h1,
.sidebar .widget h2,
.sidebar .widget h3,
.sidebar .widget h4,
.sidebar .widget h5,
.sidebar .widget h6{margin:0 0 12px;font-size:14px;font-weight:700;line-height:1.2;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}
.sidebar .widget .wp-block-heading{padding:0}
.sidebar .widget-title--bar{margin:-16px -16px 16px;padding:14px 12px;background:var(--side-head-bg);color:var(--side-head-text);border-radius:var(--radius) var(--radius) 0 0;text-align:center;font-weight:800;letter-spacing:1.2px;text-transform:uppercase}
.sidebar-card{padding:0;background:transparent;border:0}
.sidebar-avatar{display:flex;justify-content:center;margin:6px 0 14px}
.sidebar-avatar img{width:140px;height:140px;border:4px solid var(--btn-bg);border-radius:50%;object-fit:cover}
.sidebar-text{margin:0 0 12px;font-size:14px;line-height:1.65;color:var(--page-text)}
.widget_about_custom .sidebar-text{text-align:center}
.widget_disclaimer_custom .sidebar-text{text-align:left;color:var(--text-muted);font-size:13.5px;line-height:1.7}
.sidebar-cta{display:flex;align-items:center;justify-content:center;width:220px;height:52px;margin:16px auto 0;background:var(--btn-bg);color:var(--btn-text);border-radius:var(--radius-sm);font-weight:800;letter-spacing:1px;text-transform:uppercase}
.sidebar-cta:hover{background:var(--btn-hover-bg);color:var(--btn-hover-text)}

/* Hostinger sidebar ad */
.widget_hostinger_ad{padding:0;overflow:hidden}
.hostinger-ad__link{display:block}
.hostinger-ad__img{display:block;width:100%;height:auto}

/* Recent posts mini */
.recent-posts-mini{display:grid;gap:12px;list-style:none;margin:0;padding:0}
.recent-posts-mini__link{display:grid;grid-template-columns:54px minmax(0,1fr);gap:12px;align-items:center}
.recent-posts-mini__thumb img,
.recent-posts-mini__thumb--fallback{width:54px;height:54px;border-radius:var(--radius-sm)}
.recent-posts-mini__thumb img{object-fit:cover}
.recent-posts-mini__thumb--fallback{display:block;background:var(--surface)}
.recent-posts-mini__title{font-size:14px;line-height:1.25;color:var(--page-text)}
.recent-posts-mini__link:hover .recent-posts-mini__title{color:var(--nav-link-hover)}

/* =========================================================
   9) PAGINATION
   ========================================================= */
.navigation.pagination,.pagination,.pagination-split{margin:40px 0}
.navigation.pagination .nav-links,.pagination .nav-links{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:12px;width:100%}
.navigation.pagination .page-numbers,.pagination .page-numbers,.pagination-split .page-numbers,.navigation.pagination .prev,.navigation.pagination .next,.pagination .prev,.pagination .next,.pagination-split__prev a,.pagination-split__next a{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 16px;border:1px solid var(--border);border-radius:var(--radius-pill);font-size:14px;font-weight:600;text-decoration:none;transition:background .2s ease,color .2s ease,border-color .2s ease,transform .2s ease,box-shadow .2s ease}
.navigation.pagination .page-numbers,.pagination .page-numbers,.pagination-split .page-numbers{background:var(--surface);color:var(--nav-link)}
.navigation.pagination a.page-numbers:hover,.pagination a.page-numbers:hover,.pagination-split a.page-numbers:hover,.navigation.pagination a.prev:hover,.navigation.pagination a.next:hover,.pagination a.prev:hover,.pagination a.next:hover,.pagination-split__prev a:hover,.pagination-split__next a:hover{background:var(--btn-bg);color:var(--btn-text);border-color:var(--btn-bg);transform:translateY(-1px)}
.navigation.pagination .prev,.navigation.pagination .next,.pagination .prev,.pagination .next,.pagination-split__prev a,.pagination-split__next a{gap:8px;padding:0 18px;background:transparent;color:var(--brand-bg)}
.navigation.pagination .page-numbers.current,.pagination .page-numbers.current,.pagination-split .page-numbers.current{background:var(--card-bg);color:var(--brand-bg);border-color:var(--border-strong);box-shadow:0 4px 12px rgba(31,77,46,.12);cursor:default;transform:none}
.navigation.pagination .page-numbers.dots,.pagination .page-numbers.dots{min-width:auto;height:auto;padding:0 6px;background:transparent;border:0;color:var(--text-muted);box-shadow:none;cursor:default;transform:none}
.navigation.pagination span.prev,.navigation.pagination span.next,.pagination span.prev,.pagination span.next,.navigation.pagination span.page-numbers.prev,.navigation.pagination span.page-numbers.next,.pagination span.page-numbers.prev,.pagination span.page-numbers.next{background:transparent;color:var(--text-muted);border-color:var(--border);opacity:.55;cursor:not-allowed;box-shadow:none;pointer-events:none;transform:none}
.navigation.pagination .prev,.pagination .prev{margin-right:auto}
.navigation.pagination .next,.pagination .next{margin-left:auto}
.pagination-split{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;width:100%}
.pagination-split__prev{justify-self:start}
.pagination-split__nums{display:flex;align-items:center;flex-wrap:wrap;justify-self:center;gap:10px}
.pagination-split__next{justify-self:end}
@media (max-width:640px){.navigation.pagination .prev,.navigation.pagination .next,.pagination .prev,.pagination .next,.pagination-split__prev a,.pagination-split__next a{width:100%;margin:0;justify-content:center}}

/* =========================================================
   10) PAGES
   ========================================================= */
body.page .site-content article.widget{overflow:hidden;padding:22px 20px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
body.page .site-content article.widget>.post-title,
body.page .site-content .entry-title{margin:0 0 14px;color:var(--brand-bg);line-height:1.2}
body.page .site-content article.widget .post-content,
body.page .site-content article.widget .entry-content{padding:0;background:transparent;border:0;border-radius:0;box-shadow:none;color:var(--page-text)}
body.page .site-content article.widget .post-content [class*="wp-block"]{background:transparent}
body.page .site-content article.widget .post-content>*:last-child,
body.page .site-content article.widget .entry-content>*:last-child{margin-bottom:0}

/* =========================================================
   11) FOOTER
   ========================================================= */
.site-footer{padding:26px 0;background:var(--brand-bg);color:var(--brand-title);border-top:1px solid var(--white-14)}
.site-footer a{color:var(--brand-title)}
.site-footer a:hover{color:var(--footer-link-hover)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:18px}
.site-footer .footer-menu ul,
footer.site-footer .footer-menu nav.footer-nav ul.footer-menu-list{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:18px;list-style:none;margin:0;padding:0}
.site-footer .footer-menu a,
footer.site-footer .footer-menu nav.footer-nav ul.footer-menu-list>li>a{display:inline-block;padding:8px 12px;border-radius:var(--radius-pill);color:var(--brand-title);text-decoration:none}
.site-footer .footer-menu a:hover,
footer.site-footer .footer-menu nav.footer-nav ul.footer-menu-list>li>a:hover{background:transparent;color:var(--footer-link-hover)}
@media (max-width:720px){.site-footer .footer-menu ul,footer.site-footer .footer-menu nav.footer-nav ul.footer-menu-list{justify-content:center}}

/* =========================================================
   12) IMAGE CAPTIONS
   ========================================================= */
.wp-caption-text,.wp-element-caption,figcaption{margin-top:6px;color:var(--text-muted);font-size:.85em;font-weight:600;line-height:1.4;text-align:center}

/* =========================================================
   13) SINGLE PAGE FEATURED ARTICLES
   ========================================================= */
.featured-articles-title{margin:0 0 16px;font-size:1.25rem}
.featured-articles-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.featured-article-card{display:block;color:inherit;text-decoration:none}
.featured-article-image{overflow:hidden;margin-bottom:10px;border-radius:var(--radius)}
.featured-article-image img{width:100%;height:130px;object-fit:cover}
.featured-article-title{margin:0;color:var(--green);font-size:.95rem;line-height:1.35}
@media (max-width:700px){.featured-articles-grid{grid-template-columns:1fr}.featured-article-image img{height:180px}}
