/*
Theme Name: Getur Books
Theme URI: https://geturbooks.com/
Author: GeturBooks
Author URI: https://geturbooks.com/
Description: Tema WordPress untuk portal hobi & lifestyle GeturBooks. Dark navy background dengan gradient signature Purple → Blue → Green. Friendly community-oriented design: hero glow gradient, category browse grid dengan icon, soft rounded cards, multi-color tag berdasarkan kategori. "Inspirasi Hobi, Hidup Lebih Berwarna."
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 7.4
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: getur-books
Tags: blog, lifestyle, hobby, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, two-columns, right-sidebar, dark-mode
*/

:root{
  /* Brand palette — GeturBooks */
  --gb-purple:#7c3aed;        /* Creative Purple (primary) */
  --gb-purple-light:#a78bfa;
  --gb-purple-dark:#5b21b6;
  --gb-blue:#06b6d4;          /* Ocean Blue (secondary) */
  --gb-blue-light:#67e8f9;
  --gb-green:#22c55e;         /* Fresh Green (accent) */
  --gb-green-light:#4ade80;

  --gb-navy:#0f172a;          /* Deep Navy (background) */
  --gb-navy-deep:#020617;
  --gb-slate:#1e293b;         /* Slate Gray (card/surface) */
  --gb-slate-light:#334155;
  --gb-slate-lighter:#475569;

  --gb-white:#ffffff;
  --gb-text-soft:#cbd5e1;     /* Soft Gray (secondary text) */
  --gb-text-muted:#94a3b8;
  --gb-border:#334155;

  --gb-shadow:0 8px 28px rgba(0,0,0,.35);
  --gb-shadow-hover:0 16px 42px rgba(0,0,0,.5);
  --gb-glow-purple:0 0 24px rgba(124,58,237,.45);
  --gb-glow-blue:0 0 24px rgba(6,182,212,.4);
  --gb-glow-green:0 0 24px rgba(34,197,94,.4);

  --gb-radius:10px;
  --gb-radius-lg:16px;
  --gb-radius-pill:999px;

  --gb-font-display:"Poppins","Inter","Segoe UI","Helvetica Neue",Arial,sans-serif;
  --gb-font-body:"Inter","Poppins","Segoe UI","Helvetica Neue",Arial,sans-serif;

  --gb-container:1260px;
  --gb-gap:24px;
  --gb-header-h:80px;

  --gb-gradient:linear-gradient(135deg,#7c3aed 0%,#06b6d4 50%,#22c55e 100%);
  --gb-gradient-pb:linear-gradient(135deg,#7c3aed 0%,#06b6d4 100%);
  --gb-gradient-bg:linear-gradient(135deg,#06b6d4 0%,#22c55e 100%);
  --gb-gradient-text:linear-gradient(135deg,#a78bfa 0%,#67e8f9 50%,#4ade80 100%);

  /* Patterns */
  --gb-dots:radial-gradient(circle at center,rgba(124,58,237,.18) 1.2px,transparent 1.5px) 0 0/22px 22px;
  --gb-grid:linear-gradient(rgba(124,58,237,.06) 1px,transparent 1px) 0 0/40px 40px,linear-gradient(90deg,rgba(124,58,237,.06) 1px,transparent 1px) 0 0/40px 40px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;color-scheme:dark}
body{
  margin:0;
  font-family:var(--gb-font-body);
  font-size:16px;line-height:1.7;
  color:var(--gb-text-soft);
  background:var(--gb-navy);
  background-image:
    radial-gradient(ellipse 800px 400px at 15% -10%,rgba(124,58,237,.15),transparent 60%),
    radial-gradient(ellipse 700px 500px at 85% 10%,rgba(6,182,212,.1),transparent 60%);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--gb-blue-light);text-decoration:none;transition:color .15s ease}
a:hover{color:var(--gb-purple-light)}
h1,h2,h3,h4,h5,h6{
  font-family:var(--gb-font-display);
  font-weight:700;line-height:1.2;letter-spacing:-.3px;
  color:var(--gb-white);
  margin:0 0 .55em;
}
h1{font-size:clamp(2rem,4vw,3rem);font-weight:700}
h2{font-size:clamp(1.6rem,2.8vw,2.2rem)}
h3{font-size:clamp(1.2rem,1.8vw,1.4rem)}
p{margin:0 0 1em}
strong,b{color:var(--gb-white);font-weight:600}
blockquote{
  border-left:4px solid transparent;
  border-image:var(--gb-gradient) 1;
  padding:.6em 1.4em;margin:1.6em 0;
  background:rgba(124,58,237,.08);
  font-style:italic;color:var(--gb-text-soft);
  border-radius:0 var(--gb-radius) var(--gb-radius) 0;
}
code,pre{font-family:"JetBrains Mono",Consolas,monospace;font-size:.92em}
code{background:rgba(124,58,237,.18);color:var(--gb-purple-light);padding:.15em .45em;border-radius:4px}
pre{background:var(--gb-navy-deep);color:#e8e8e8;padding:1em;border-radius:var(--gb-radius);overflow:auto;border:1px solid var(--gb-border)}
hr{
  border:0;height:2px;
  background:var(--gb-gradient);
  margin:2.6em 0;border-radius:2px;opacity:.6;
}
:focus-visible{outline:3px solid var(--gb-purple-light);outline-offset:2px}

::selection{background:var(--gb-purple);color:#fff}

/* Gradient text utility */
.gb-grad-text{
  background:var(--gb-gradient-text);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}

/* ---------- Layout ---------- */
.gb-container{max-width:var(--gb-container);margin:0 auto;padding:0 22px}
.gb-grid{display:grid;gap:var(--gb-gap)}
.gb-main-wrap{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:36px;padding:36px 0 64px}
@media (max-width:1000px){.gb-main-wrap{grid-template-columns:1fr}}

/* ---------- Topbar ---------- */
.gb-topbar{
  background:var(--gb-navy-deep);color:var(--gb-text-muted);font-size:.8rem;
  border-bottom:1px solid var(--gb-border);
}
.gb-topbar-inner{display:flex;align-items:center;justify-content:space-between;min-height:34px;gap:16px;flex-wrap:wrap}
.gb-topbar-date{display:flex;align-items:center;gap:10px;color:var(--gb-text-soft)}
.gb-topbar-date::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:var(--gb-gradient-bg);box-shadow:var(--gb-glow-green);
  animation:gb-pulse 2s infinite;
}
@keyframes gb-pulse{0%,100%{opacity:.8}50%{opacity:1}}
.gb-topbar-social a{color:var(--gb-text-muted);margin-left:12px;display:inline-flex;align-items:center}
.gb-topbar-social a:hover{color:var(--gb-purple-light)}

/* ---------- Header ---------- */
.gb-header{
  background:rgba(15,23,42,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  color:var(--gb-white);position:sticky;top:0;z-index:50;
  border-bottom:1px solid var(--gb-border);
  transition:box-shadow .2s ease,background .2s ease;
}
.gb-header.is-stuck{background:rgba(15,23,42,.97);box-shadow:0 8px 32px rgba(0,0,0,.35)}
.gb-header-inner{display:flex;align-items:center;justify-content:space-between;min-height:var(--gb-header-h);gap:24px}

.gb-brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--gb-white);flex-shrink:0}
.custom-logo-link{
  display:inline-flex;align-items:center;line-height:0;text-decoration:none;
  padding:7px 14px;
  background:linear-gradient(135deg,rgba(124,58,237,.12) 0%,rgba(6,182,212,.08) 100%);
  border:1px solid rgba(124,58,237,.32);
  border-radius:12px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 0 20px rgba(124,58,237,.15);
  transition:all .15s ease;
}
.custom-logo-link:hover{
  background:linear-gradient(135deg,rgba(124,58,237,.2) 0%,rgba(6,182,212,.12) 100%);
  border-color:rgba(124,58,237,.55);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 0 26px rgba(124,58,237,.3);
}
.custom-logo{
  width:auto!important;max-width:220px!important;height:auto!important;max-height:50px!important;
  display:block!important;object-fit:contain;
  filter:drop-shadow(0 0 10px rgba(167,139,250,.55)) drop-shadow(0 4px 14px rgba(6,182,212,.22));
}
@media (max-width:600px){
  .custom-logo-link{padding:5px 10px;border-radius:10px}
  .custom-logo{max-width:150px!important;max-height:40px!important}
}

.gb-brand-mark{
  width:46px;height:46px;border-radius:12px;
  background:var(--gb-gradient-pb);color:#fff;
  display:grid;place-items:center;font-family:var(--gb-font-display);
  font-size:1.4rem;font-weight:700;letter-spacing:.5px;
  box-shadow:var(--gb-glow-purple);
  position:relative;
}
.gb-brand-mark::after{
  content:"";position:absolute;inset:-3px;border-radius:14px;
  background:var(--gb-gradient);z-index:-1;opacity:.5;filter:blur(8px);
}
.gb-brand-text{display:flex;flex-direction:column;line-height:1.1}
.gb-brand-name{font-family:var(--gb-font-display);font-size:1.3rem;font-weight:700;letter-spacing:-.3px;color:#fff}
.gb-brand-name em{
  font-style:normal;
  background:var(--gb-gradient-text);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.gb-brand-tag{font-size:.72rem;color:var(--gb-text-muted);margin-top:3px;font-weight:400}

.gb-nav{display:flex;align-items:center;flex:1;justify-content:center}
.gb-nav ul{list-style:none;display:flex;align-items:center;gap:2px;margin:0;padding:0;flex-wrap:nowrap}
.gb-nav a{
  position:relative;display:flex;align-items:center;height:var(--gb-header-h);
  padding:0 14px;color:var(--gb-text-soft);font-weight:500;
  font-family:var(--gb-font-display);font-size:.95rem;letter-spacing:-.1px;
  white-space:nowrap;line-height:1;transition:color .15s ease;
}
.gb-nav a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:18px;height:2px;
  background:var(--gb-gradient);border-radius:2px;
  transform:scaleX(0);transform-origin:center;transition:transform .2s ease;
}
.gb-nav a:hover,.gb-nav .current-menu-item>a,.gb-nav .current_page_item>a{color:#fff}
.gb-nav a:hover::after,.gb-nav .current-menu-item>a::after,.gb-nav .current_page_item>a::after{transform:scaleX(1)}
.gb-nav li{position:relative}
.gb-nav .sub-menu{
  position:absolute;top:100%;left:0;background:var(--gb-slate);min-width:230px;
  box-shadow:var(--gb-shadow-hover);padding:8px;display:none;
  border:1px solid var(--gb-border);border-radius:var(--gb-radius);margin-top:6px;z-index:60;
}
.gb-nav li:hover>.sub-menu,.gb-nav li:focus-within>.sub-menu{display:block}
.gb-nav .sub-menu a{padding:10px 14px;font-size:.88rem;height:auto;border-radius:6px}
.gb-nav .sub-menu a:hover{background:rgba(124,58,237,.15)}
.gb-nav .sub-menu a::after{display:none}

@media (max-width:1180px){.gb-nav a{padding:0 11px;font-size:.9rem}}
@media (max-width:1040px){.gb-nav a{padding:0 9px;font-size:.85rem}}

.gb-header-actions{display:flex;align-items:center;gap:6px}
.gb-icon-btn{
  width:42px;height:42px;display:grid;place-items:center;background:transparent;
  border:1px solid var(--gb-border);border-radius:10px;cursor:pointer;color:var(--gb-text-soft);
  transition:all .15s ease;
}
.gb-icon-btn:hover{background:var(--gb-gradient-pb);border-color:transparent;color:#fff;box-shadow:var(--gb-glow-purple)}
.gb-icon-btn svg{width:20px;height:20px}

.gb-cta-btn{
  display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--gb-radius-pill);
  background:var(--gb-gradient-pb);color:#fff;font-family:var(--gb-font-display);font-weight:600;
  font-size:.88rem;border:0;cursor:pointer;transition:all .15s ease;
  box-shadow:var(--gb-glow-purple);
}
.gb-cta-btn:hover{transform:translateY(-2px);color:#fff;box-shadow:0 0 32px rgba(124,58,237,.6)}

.gb-menu-toggle{display:none}
@media (max-width:1000px){
  .gb-menu-toggle{display:grid}
  .gb-nav{
    position:fixed;inset:var(--gb-header-h) 0 0 0;background:var(--gb-navy);flex-direction:column;
    align-items:stretch;padding:20px;transform:translateX(-100%);transition:transform .25s ease;
    overflow-y:auto;z-index:55;justify-content:flex-start;
  }
  .gb-nav.is-open{transform:translateX(0)}
  .gb-nav ul{flex-direction:column;gap:0;width:100%;flex-wrap:wrap}
  .gb-nav a{
    display:block;height:auto;padding:14px 16px;border-bottom:1px solid var(--gb-border);
    font-size:1rem;border-radius:0;
  }
  .gb-nav a::after{display:none}
  .gb-nav a:hover,.gb-nav .current-menu-item>a,.gb-nav .current_page_item>a{background:rgba(124,58,237,.15);color:#fff}
  .gb-nav .sub-menu{position:static;box-shadow:none;border:0;border-left:3px solid var(--gb-purple);padding-left:8px;display:block;margin:0;border-radius:0}
}

/* ---------- Search overlay ---------- */
.gb-search-overlay{
  position:fixed;inset:0;background:rgba(2,6,23,.96);display:none;backdrop-filter:blur(10px);
  align-items:flex-start;justify-content:center;padding:14vh 22px;z-index:90;
}
.gb-search-overlay.is-open{display:flex;animation:gb-fade .15s ease}
@keyframes gb-fade{from{opacity:0}to{opacity:1}}
.gb-search-overlay form{
  width:100%;max-width:680px;display:flex;gap:0;
  border-radius:var(--gb-radius-pill);overflow:hidden;
  box-shadow:0 0 0 2px var(--gb-purple),0 0 40px rgba(124,58,237,.4);
}
.gb-search-overlay input[type=search]{
  flex:1;padding:18px 26px;font-size:1.1rem;border:0;background:var(--gb-slate);color:#fff;
  font-family:var(--gb-font-body);
}
.gb-search-overlay input[type=search]::placeholder{color:var(--gb-text-muted)}
.gb-search-overlay button{
  padding:0 30px;background:var(--gb-gradient-pb);color:#fff;border:0;
  font-family:var(--gb-font-display);font-weight:600;cursor:pointer;font-size:1rem;
}
.gb-search-close{position:absolute;top:24px;right:24px;color:#fff;background:transparent;border:0;cursor:pointer;font-size:2rem}

/* ---------- Hero ---------- */
.gb-hero{position:relative;padding:60px 0 24px;overflow:hidden}
.gb-hero::before{
  content:"";position:absolute;inset:0;
  background:var(--gb-dots);opacity:.4;
  mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);
}
.gb-hero-inner{position:relative;z-index:2}
.gb-hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;padding:6px 14px;
  border-radius:var(--gb-radius-pill);background:rgba(124,58,237,.15);
  color:var(--gb-purple-light);font-size:.8rem;font-weight:500;letter-spacing:.5px;
  border:1px solid rgba(124,58,237,.3);margin-bottom:18px;
}
.gb-hero-eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gb-purple-light)}
.gb-hero-title{
  font-size:clamp(2rem,5vw,3.6rem);font-weight:700;letter-spacing:-.5px;margin-bottom:14px;line-height:1.1;
  max-width:780px;
}
.gb-hero-excerpt{
  color:var(--gb-text-soft);font-size:1.1rem;max-width:620px;margin-bottom:24px;line-height:1.6;
}
.gb-hero-actions{display:flex;gap:12px;flex-wrap:wrap}

.gb-hero-featured{
  display:grid;grid-template-columns:1.5fr 1fr;gap:24px;margin-top:40px;
}
@media (max-width:900px){.gb-hero-featured{grid-template-columns:1fr}}

.gb-hero-main{
  position:relative;border-radius:var(--gb-radius-lg);overflow:hidden;
  aspect-ratio:16/10;min-height:360px;
  background:var(--gb-slate);box-shadow:var(--gb-shadow);
  display:block;color:#fff;text-decoration:none;
}
.gb-hero-main::before{
  content:"";position:absolute;inset:-2px;border-radius:var(--gb-radius-lg);
  background:var(--gb-gradient);z-index:-1;opacity:.6;filter:blur(20px);
}
.gb-hero-main img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gb-hero-main:hover img{transform:scale(1.04)}
.gb-hero-main-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,23,42,0) 35%,rgba(2,6,23,.95) 100%)}
.gb-hero-main-content{position:absolute;left:0;right:0;bottom:0;padding:28px;z-index:2}
.gb-hero-main-cat{
  display:inline-block;padding:5px 14px;border-radius:var(--gb-radius-pill);
  background:rgba(124,58,237,.85);color:#fff;font-size:.75rem;font-weight:600;letter-spacing:.5px;
  margin-bottom:12px;backdrop-filter:blur(4px);
}
.gb-hero-main-title{font-size:clamp(1.3rem,2.2vw,1.8rem);color:#fff;margin:0 0 10px;line-height:1.2}
.gb-hero-main-meta{display:flex;gap:14px;font-size:.82rem;color:rgba(255,255,255,.75)}

.gb-hero-side{display:flex;flex-direction:column;gap:18px}
.gb-hero-side article{
  position:relative;background:var(--gb-slate);border-radius:var(--gb-radius);overflow:hidden;
  display:grid;grid-template-columns:120px 1fr;gap:0;align-items:center;
  transition:transform .15s ease,box-shadow .15s ease;border:1px solid var(--gb-border);
}
.gb-hero-side article:hover{transform:translateX(4px);box-shadow:var(--gb-shadow-hover);border-color:var(--gb-purple)}
.gb-hero-side-img{width:120px;height:100px;overflow:hidden;background:var(--gb-navy)}
.gb-hero-side-img img{width:100%;height:100%;object-fit:cover}
.gb-hero-side-body{padding:14px 16px}
.gb-hero-side-body h4{font-size:.95rem;margin:0 0 5px;line-height:1.3;font-weight:600}
.gb-hero-side-body h4 a{color:#fff}
.gb-hero-side-body h4 a:hover{color:var(--gb-purple-light)}
.gb-hero-side-body .gb-meta{font-size:.74rem;color:var(--gb-text-muted)}

/* ---------- Section ---------- */
.gb-section{padding:32px 0}
.gb-section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.gb-section-title{
  font-family:var(--gb-font-display);font-size:1.7rem;margin:0;font-weight:700;letter-spacing:-.3px;
  color:#fff;display:flex;align-items:center;gap:12px;
}
.gb-section-title::before{
  content:"";width:6px;height:28px;border-radius:3px;background:var(--gb-gradient);
}
.gb-section-sub{color:var(--gb-text-muted);font-size:.95rem;margin:6px 0 0}
.gb-section-more{
  display:inline-flex;align-items:center;gap:6px;color:var(--gb-purple-light);font-size:.88rem;font-weight:500;
  padding:8px 16px;border-radius:var(--gb-radius-pill);border:1px solid var(--gb-border);transition:all .15s ease;
}
.gb-section-more:hover{background:rgba(124,58,237,.15);border-color:var(--gb-purple);color:#fff}

/* ---------- Category browse grid ---------- */
.gb-cats{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.gb-cat-card{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  padding:24px 16px;background:var(--gb-slate);border:1px solid var(--gb-border);
  border-radius:var(--gb-radius);text-align:center;color:var(--gb-white);
  transition:all .2s ease;position:relative;overflow:hidden;
}
.gb-cat-card::before{
  content:"";position:absolute;inset:0;background:var(--gb-gradient);
  opacity:0;transition:opacity .2s ease;z-index:0;
}
.gb-cat-card:hover{transform:translateY(-3px);border-color:transparent;box-shadow:var(--gb-glow-purple);color:#fff}
.gb-cat-card:hover::before{opacity:.85}
.gb-cat-card>*{position:relative;z-index:1}
.gb-cat-icon{
  width:56px;height:56px;border-radius:50%;display:grid;place-items:center;
  background:var(--gb-gradient-pb);color:#fff;box-shadow:var(--gb-glow-purple);
}
.gb-cat-icon svg{width:26px;height:26px}
.gb-cat-card:nth-child(2n) .gb-cat-icon{background:var(--gb-gradient-bg);box-shadow:var(--gb-glow-blue)}
.gb-cat-card:nth-child(3n) .gb-cat-icon{background:linear-gradient(135deg,#22c55e 0%,#06b6d4 100%);box-shadow:var(--gb-glow-green)}
.gb-cat-name{font-family:var(--gb-font-display);font-size:.95rem;font-weight:600;letter-spacing:-.1px;color:#fff}
.gb-cat-count{font-size:.74rem;color:var(--gb-text-muted);font-weight:500}
.gb-cat-card:hover .gb-cat-count{color:rgba(255,255,255,.85)}

/* ---------- Cards (post grid) ---------- */
.gb-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--gb-gap)}
.gb-card{
  background:var(--gb-slate);border:1px solid var(--gb-border);
  border-radius:var(--gb-radius);overflow:hidden;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
  display:flex;flex-direction:column;position:relative;
}
.gb-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--gb-gradient);opacity:0;transition:opacity .2s ease;z-index:2;
}
.gb-card:hover{transform:translateY(-4px);box-shadow:var(--gb-shadow-hover);border-color:var(--gb-purple)}
.gb-card:hover::before{opacity:1}
.gb-card-img{position:relative;aspect-ratio:16/10;background:var(--gb-navy);overflow:hidden}
.gb-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gb-card:hover .gb-card-img img{transform:scale(1.05)}
.gb-card-cat{
  position:absolute;top:12px;left:12px;
  background:rgba(2,6,23,.7);color:#fff;backdrop-filter:blur(6px);
  font-size:.72rem;font-weight:600;letter-spacing:.3px;padding:5px 12px;border-radius:var(--gb-radius-pill);
  border:1px solid rgba(124,58,237,.4);
}
.gb-card-body{padding:18px;display:flex;flex-direction:column;flex:1}
.gb-card-title{font-size:1.08rem;margin:0 0 8px;line-height:1.35;font-weight:600;letter-spacing:-.2px}
.gb-card-title a{color:#fff}
.gb-card-title a:hover{color:var(--gb-purple-light)}
.gb-card-excerpt{color:var(--gb-text-muted);font-size:.88rem;margin:0 0 14px;flex:1;line-height:1.6}
.gb-card-meta{display:flex;gap:12px;font-size:.76rem;color:var(--gb-text-muted);
  border-top:1px solid var(--gb-border);padding-top:12px;margin-top:auto}
.gb-card-meta span{display:inline-flex;align-items:center;gap:5px}

/* ---------- Featured/horizontal cards ---------- */
.gb-feed{display:flex;flex-direction:column;gap:18px}
.gb-card-h{
  display:grid;grid-template-columns:280px 1fr;gap:0;background:var(--gb-slate);
  border:1px solid var(--gb-border);border-radius:var(--gb-radius);overflow:hidden;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.gb-card-h:hover{transform:translateY(-3px);box-shadow:var(--gb-shadow-hover);border-color:var(--gb-purple)}
.gb-card-h-img{position:relative;aspect-ratio:4/3;background:var(--gb-navy);overflow:hidden}
.gb-card-h-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gb-card-h:hover .gb-card-h-img img{transform:scale(1.06)}
.gb-card-h-cat{
  position:absolute;top:12px;left:12px;
  background:var(--gb-gradient-pb);color:#fff;
  font-size:.72rem;font-weight:600;padding:5px 12px;border-radius:var(--gb-radius-pill);
}
.gb-card-h-body{padding:22px 26px;display:flex;flex-direction:column;justify-content:center}
.gb-card-h-title{font-size:1.3rem;margin:0 0 10px;line-height:1.25;font-weight:600;letter-spacing:-.3px}
.gb-card-h-title a{color:#fff}
.gb-card-h-title a:hover{color:var(--gb-purple-light)}
.gb-card-h-excerpt{color:var(--gb-text-muted);font-size:.93rem;margin:0 0 14px;line-height:1.6}
.gb-card-h-meta{display:flex;gap:16px;font-size:.8rem;color:var(--gb-text-muted)}
.gb-card-h-meta span{display:flex;align-items:center;gap:6px}

@media (max-width:600px){
  .gb-card-h{grid-template-columns:1fr}
  .gb-card-h-img{aspect-ratio:16/9}
  .gb-card-h-body{padding:18px}
}

/* ---------- Hobby card shortcode ---------- */
.gb-hobby-card{
  background:var(--gb-slate);border:1px solid var(--gb-border);
  border-radius:var(--gb-radius-lg);padding:24px;text-align:center;
  transition:all .2s ease;position:relative;overflow:hidden;display:block;color:inherit;
}
.gb-hobby-card::before{
  content:"";position:absolute;top:-1px;left:-1px;right:-1px;height:4px;
  background:var(--gb-gradient);border-radius:var(--gb-radius-lg) var(--gb-radius-lg) 0 0;
  opacity:.8;
}
.gb-hobby-card:hover{transform:translateY(-4px);border-color:var(--gb-purple);box-shadow:var(--gb-glow-purple)}
.gb-hobby-icon{
  width:64px;height:64px;margin:0 auto 16px;border-radius:16px;
  background:var(--gb-gradient-pb);display:grid;place-items:center;
  box-shadow:var(--gb-glow-purple);color:#fff;
}
.gb-hobby-icon svg{width:30px;height:30px}
.gb-hobby-card h4{margin:0 0 8px;color:#fff;font-size:1.1rem}
.gb-hobby-card p{margin:0;color:var(--gb-text-muted);font-size:.9rem}

/* ---------- Gradient quote ---------- */
.gb-grad-quote{
  position:relative;padding:30px 32px;border-radius:var(--gb-radius-lg);
  background:linear-gradient(135deg,rgba(124,58,237,.15) 0%,rgba(6,182,212,.12) 50%,rgba(34,197,94,.12) 100%);
  border:1px solid rgba(124,58,237,.3);margin:28px 0;
  font-family:var(--gb-font-display);font-size:1.25rem;font-weight:500;color:#fff;line-height:1.5;
}
.gb-grad-quote::before{
  content:"\201C";position:absolute;top:0;left:18px;font-size:5rem;line-height:1;
  background:var(--gb-gradient-text);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;font-family:Georgia,serif;
}
.gb-grad-quote-cite{display:block;font-size:.88rem;color:var(--gb-text-soft);margin-top:12px;font-weight:400;font-style:italic}

/* ---------- Sidebar ---------- */
.gb-sidebar{display:flex;flex-direction:column;gap:22px}
.gb-widget{
  background:var(--gb-slate);border:1px solid var(--gb-border);
  border-radius:var(--gb-radius);padding:22px;
  position:relative;overflow:hidden;
}
.gb-widget::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--gb-gradient);
}
.gb-widget h3,.gb-widget .widget-title{
  font-size:1.05rem;margin:0 0 14px;padding-bottom:12px;
  border-bottom:1px solid var(--gb-border);font-family:var(--gb-font-display);font-weight:600;
  color:#fff;letter-spacing:-.2px;
}
.gb-widget ul{list-style:none;margin:0;padding:0}
.gb-widget li{padding:9px 0;border-bottom:1px solid var(--gb-border);font-size:.92rem}
.gb-widget li:last-child{border-bottom:0}
.gb-widget a{color:var(--gb-text-soft)}
.gb-widget a:hover{color:var(--gb-purple-light)}

.gb-side-card{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--gb-border)}
.gb-side-card:last-child{border-bottom:0}
.gb-side-card-img{width:80px;height:60px;flex-shrink:0;border-radius:6px;overflow:hidden;background:var(--gb-navy)}
.gb-side-card-img img{width:100%;height:100%;object-fit:cover}
.gb-side-card-body{flex:1;min-width:0}
.gb-side-card-body h4{font-size:.88rem;margin:0 0 4px;line-height:1.3;font-weight:500;color:#fff}
.gb-side-card-body h4 a{color:#fff}
.gb-side-card-body h4 a:hover{color:var(--gb-purple-light)}
.gb-side-card-meta{font-size:.72rem;color:var(--gb-text-muted)}

/* Newsletter widget */
.gb-newsletter{
  background:linear-gradient(135deg,rgba(124,58,237,.15) 0%,rgba(6,182,212,.1) 100%);
  border:1px solid rgba(124,58,237,.35)!important;
}
.gb-newsletter input{
  width:100%;padding:11px 14px;border-radius:var(--gb-radius);
  background:var(--gb-navy);border:1px solid var(--gb-border);color:#fff;
  font-family:inherit;font-size:.9rem;margin-bottom:10px;
}
.gb-newsletter input::placeholder{color:var(--gb-text-muted)}
.gb-newsletter input:focus{outline:none;border-color:var(--gb-purple)}

/* Tag cloud */
.gb-tagcloud{display:flex;flex-wrap:wrap;gap:6px}
.gb-tagcloud a{
  padding:5px 12px;border-radius:var(--gb-radius-pill);
  background:rgba(124,58,237,.12);color:var(--gb-purple-light)!important;
  font-size:.78rem;font-weight:500;border:1px solid rgba(124,58,237,.25);transition:all .15s ease;
}
.gb-tagcloud a:nth-child(2n){background:rgba(6,182,212,.12);color:var(--gb-blue-light)!important;border-color:rgba(6,182,212,.25)}
.gb-tagcloud a:nth-child(3n){background:rgba(34,197,94,.12);color:var(--gb-green-light)!important;border-color:rgba(34,197,94,.25)}
.gb-tagcloud a:hover{background:var(--gb-gradient-pb)!important;color:#fff!important;border-color:transparent}

/* ---------- Single post ---------- */
.gb-article{
  background:var(--gb-slate);border:1px solid var(--gb-border);
  border-radius:var(--gb-radius-lg);padding:36px;
  position:relative;overflow:hidden;
}
.gb-article::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:var(--gb-gradient);
}
.gb-article-cat{
  display:inline-flex;align-items:center;padding:6px 16px;border-radius:var(--gb-radius-pill);
  background:var(--gb-gradient-pb);color:#fff;font-size:.82rem;font-weight:600;
  letter-spacing:.3px;margin-bottom:16px;box-shadow:var(--gb-glow-purple);
}
.gb-article h1{margin-bottom:16px;color:#fff;letter-spacing:-.5px}
.gb-article-meta{
  display:flex;gap:22px;flex-wrap:wrap;font-size:.84rem;color:var(--gb-text-muted);
  padding-bottom:18px;margin-bottom:26px;border-bottom:1px solid var(--gb-border);
}
.gb-article-meta span{display:flex;align-items:center;gap:6px}
.gb-article-thumb{margin:0 -36px 26px;position:relative;aspect-ratio:16/9;overflow:hidden}
.gb-article-thumb img{width:100%;height:100%;object-fit:cover}
.gb-article-content{font-size:1.05rem;line-height:1.8;color:var(--gb-text-soft)}
.gb-article-content p:first-of-type::first-letter{
  float:left;font-family:var(--gb-font-display);font-size:3.8rem;line-height:.85;
  padding:8px 14px 0 0;font-weight:700;
  background:var(--gb-gradient-text);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.gb-article-content h2,.gb-article-content h3{margin-top:1.5em;color:#fff;letter-spacing:-.3px}
.gb-article-content h2{font-size:1.7rem;padding-left:16px;border-left:4px solid transparent;border-image:var(--gb-gradient) 1}
.gb-article-content h3{font-size:1.3rem}
.gb-article-content img{border-radius:var(--gb-radius);margin:1.2em 0}
.gb-article-content ul,.gb-article-content ol{padding-left:1.6em}
.gb-article-content li{margin-bottom:.5em}
.gb-article-content a{text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}

.gb-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px;align-items:center}
.gb-tag{
  padding:6px 14px;border-radius:var(--gb-radius-pill);
  background:rgba(124,58,237,.15);color:var(--gb-purple-light);
  font-size:.78rem;font-weight:500;border:1px solid rgba(124,58,237,.3);transition:all .15s ease;
}
.gb-tag:hover{background:var(--gb-gradient-pb);color:#fff;border-color:transparent}

.gb-share{display:flex;gap:10px;margin-top:28px;padding-top:22px;border-top:1px solid var(--gb-border);align-items:center}
.gb-share-label{font-size:.9rem;color:var(--gb-text-soft);margin-right:6px;font-weight:600}
.gb-share a{
  width:40px;height:40px;display:grid;place-items:center;border-radius:10px;
  background:var(--gb-navy);color:var(--gb-text-soft);transition:all .15s ease;
  border:1px solid var(--gb-border);
}
.gb-share a:hover{background:var(--gb-gradient-pb);color:#fff;border-color:transparent;transform:translateY(-2px);box-shadow:var(--gb-glow-purple)}
.gb-share svg,.gb-topbar-social svg,.gb-footer-social svg{width:18px;height:18px;display:block}
.gb-tags svg{width:14px;height:14px}

.gb-author-box{
  display:flex;gap:18px;
  background:linear-gradient(135deg,rgba(124,58,237,.12) 0%,rgba(6,182,212,.08) 100%);
  border:1px solid rgba(124,58,237,.3);padding:24px;border-radius:var(--gb-radius);
  margin-top:32px;align-items:flex-start;
}
.gb-author-box img{width:64px;height:64px;border-radius:50%;flex-shrink:0;border:2px solid var(--gb-purple)}
.gb-author-box h4{margin:0 0 6px;color:#fff}
.gb-author-box p{font-size:.92rem;color:var(--gb-text-soft);margin:0;line-height:1.6}

.gb-related{margin-top:48px}

/* ---------- Pagination ---------- */
.gb-pagination{display:flex;gap:6px;justify-content:center;margin-top:36px;flex-wrap:wrap}
.gb-pagination .page-numbers{
  padding:11px 16px;background:var(--gb-slate);color:var(--gb-text-soft);
  border:1px solid var(--gb-border);border-radius:var(--gb-radius);
  font-weight:600;font-size:.9rem;transition:all .15s ease;
}
.gb-pagination .page-numbers:hover,.gb-pagination .current{background:var(--gb-gradient-pb);color:#fff;border-color:transparent;box-shadow:var(--gb-glow-purple)}

/* ---------- Buttons ---------- */
.gb-btn{
  display:inline-flex;align-items:center;gap:8px;padding:12px 24px;
  background:var(--gb-gradient-pb);color:#fff;border-radius:var(--gb-radius-pill);
  font-family:var(--gb-font-display);font-weight:600;font-size:.92rem;
  border:0;cursor:pointer;transition:all .15s ease;
  box-shadow:var(--gb-glow-purple);
}
.gb-btn:hover{color:#fff;transform:translateY(-2px);box-shadow:0 0 32px rgba(124,58,237,.55)}
.gb-btn-outline{background:transparent;color:var(--gb-text-soft);border:1px solid var(--gb-border);box-shadow:none}
.gb-btn-outline:hover{background:rgba(124,58,237,.15);border-color:var(--gb-purple);color:#fff;box-shadow:none}

/* ---------- Banner area ---------- */
.gb-banner-area{
  display:flex;flex-direction:column;gap:18px;
  margin:40px 0;padding-top:26px;
  border-top:1px dashed var(--gb-border);
}
.gb-banner-area::before{
  content:"Sponsor";font-family:var(--gb-font-display);text-transform:uppercase;letter-spacing:2px;
  font-size:.7rem;color:var(--gb-text-muted);text-align:center;margin-bottom:-6px;font-weight:600;
}
.gb-banner-area--after_latest{margin-top:40px}
.gb-banner-area--after_hero{margin:0 0 28px;padding-top:0;border-top:0}
.gb-banner-area--after_hero::before{display:none}
.gb-banner-area--before_footer{margin:48px 0 0}
.gb-banner{
  position:relative;display:block;width:100%;border-radius:var(--gb-radius);overflow:hidden;
  background:var(--gb-slate);box-shadow:var(--gb-shadow);
  transition:transform .2s ease,box-shadow .2s ease;text-decoration:none;
  border:1px solid var(--gb-border);
}
.gb-banner:hover{transform:translateY(-2px);box-shadow:var(--gb-shadow-hover);border-color:var(--gb-purple)}
.gb-banner-img{display:block;width:100%;height:auto;object-fit:cover;max-height:280px}
.gb-banner-label{
  position:absolute;left:10px;top:10px;background:rgba(2,6,23,.85);color:#fff;
  font-size:.7rem;padding:4px 12px;border-radius:var(--gb-radius-pill);font-weight:600;
  border:1px solid rgba(124,58,237,.4);
}
@media (max-width:600px){.gb-banner-img{max-height:180px}}

/* ---------- Footer brand/logo ---------- */
.gb-footer-brand{
  display:inline-flex;align-items:center;gap:12px;text-decoration:none;color:var(--gb-white);
  padding:12px 18px;
  background:linear-gradient(135deg,rgba(124,58,237,.12) 0%,rgba(6,182,212,.08) 100%);
  border:1px solid rgba(124,58,237,.35);
  border-radius:14px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 0 24px rgba(124,58,237,.15);
  transition:all .15s ease;
}
.gb-footer-brand:hover{
  background:linear-gradient(135deg,rgba(124,58,237,.2) 0%,rgba(6,182,212,.12) 100%);
  border-color:rgba(124,58,237,.55);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),var(--gb-glow-purple);
}
.gb-footer-logo{
  width:auto;height:auto;max-width:240px;max-height:54px;
  display:block;object-fit:contain;
  filter:drop-shadow(0 0 12px rgba(167,139,250,.55)) drop-shadow(0 4px 16px rgba(6,182,212,.25));
}

/* ---------- Footer ---------- */
.gb-footer{
  background:var(--gb-navy-deep);color:var(--gb-text-soft);padding:60px 0 0;margin-top:60px;
  position:relative;border-top:1px solid var(--gb-border);
}
.gb-footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--gb-gradient);
}
.gb-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:40px}
@media (max-width:780px){.gb-footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.gb-footer-grid{grid-template-columns:1fr}}
.gb-footer h4{color:#fff;font-size:1rem;margin-bottom:18px;font-family:var(--gb-font-display);font-weight:600;letter-spacing:-.2px;position:relative;padding-bottom:10px}
.gb-footer h4::after{content:"";position:absolute;left:0;bottom:0;width:32px;height:3px;background:var(--gb-gradient);border-radius:2px}
.gb-footer ul{list-style:none;margin:0;padding:0}
.gb-footer li{margin-bottom:10px;font-size:.92rem}
.gb-footer a{color:var(--gb-text-soft)}
.gb-footer a:hover{color:var(--gb-purple-light)}
.gb-footer-about{font-size:.92rem;line-height:1.7}
.gb-footer-social{display:flex;gap:8px;margin-top:16px}
.gb-footer-social a{
  width:40px;height:40px;display:grid;place-items:center;border-radius:10px;background:var(--gb-slate);
  color:#fff;border:1px solid var(--gb-border);transition:all .15s ease;
}
.gb-footer-social a:hover{background:var(--gb-gradient-pb);border-color:transparent;transform:translateY(-2px);box-shadow:var(--gb-glow-purple)}
.gb-footer-bottom{border-top:1px solid var(--gb-border);padding:20px 0;font-size:.84rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--gb-text-muted)}
.gb-footer-mood{display:flex;gap:18px;flex-wrap:wrap;font-size:.76rem;color:var(--gb-text-muted)}
.gb-footer-mood span{display:inline-flex;align-items:center;gap:5px}

/* ---------- Misc ---------- */
.gb-breadcrumb{font-size:.82rem;color:var(--gb-text-muted);margin-bottom:14px}
.gb-breadcrumb a{color:var(--gb-text-soft)}
.gb-breadcrumb a:hover{color:var(--gb-purple-light)}
.gb-breadcrumb span{margin:0 8px;color:var(--gb-text-muted)}

.gb-archive-head{
  background:linear-gradient(135deg,rgba(124,58,237,.18) 0%,rgba(6,182,212,.12) 100%);
  border:1px solid rgba(124,58,237,.3);border-radius:var(--gb-radius);
  padding:30px;margin-bottom:26px;position:relative;overflow:hidden;
}
.gb-archive-head::before{
  content:"";position:absolute;inset:0;background:var(--gb-dots);opacity:.5;
}
.gb-archive-head>*{position:relative;z-index:1}
.gb-archive-head h1{margin:0 0 8px;font-size:1.9rem;color:#fff;letter-spacing:-.3px}
.gb-archive-head p{margin:0;color:var(--gb-text-soft);font-size:.95rem}

.gb-404{text-align:center;padding:80px 22px;background:var(--gb-slate);border:1px solid var(--gb-border);border-radius:var(--gb-radius-lg)}
.gb-404-code{
  font-family:var(--gb-font-display);font-size:10rem;line-height:1;margin:0;font-weight:700;letter-spacing:-4px;
  background:var(--gb-gradient-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.gb-404 h1{margin:20px 0 8px;color:#fff}
.gb-404 p{color:var(--gb-text-muted);max-width:500px;margin:0 auto 22px}

.screen-reader-text{position:absolute;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}
.alignleft{float:left;margin:0 1em 1em 0}
.alignright{float:right;margin:0 0 1em 1em}
.aligncenter{margin-left:auto;margin-right:auto;display:block}
.wp-caption{margin-bottom:1em;max-width:100%}
.wp-caption-text{font-size:.85rem;color:var(--gb-text-muted);text-align:center;margin-top:6px;font-style:italic}

/* Comments */
.gb-comments{margin-top:48px;background:var(--gb-slate);border:1px solid var(--gb-border);padding:32px;border-radius:var(--gb-radius)}
.gb-comments-title{font-size:1.4rem;margin-bottom:22px;padding-bottom:10px;color:#fff;display:inline-block;border-bottom:3px solid transparent;border-image:var(--gb-gradient) 1}
.gb-comments .comment-list{list-style:none;padding:0;margin:0 0 26px}
.gb-comments .comment{padding:18px 0;border-bottom:1px solid var(--gb-border)}
.gb-comments .comment .avatar{border-radius:50%;float:left;margin-right:14px;border:2px solid var(--gb-purple)}
.gb-comments .comment-author{font-weight:600;color:#fff}
.gb-comments .comment-meta{font-size:.78rem;color:var(--gb-text-muted);margin-bottom:8px}
.gb-comments-form label{display:block;font-weight:500;margin:12px 0 4px;font-size:.88rem;color:var(--gb-text-soft)}
.gb-comments-form input[type=text],.gb-comments-form input[type=email],.gb-comments-form input[type=url],.gb-comments-form textarea{
  width:100%;padding:12px 14px;border:1px solid var(--gb-border);border-radius:var(--gb-radius);
  background:var(--gb-navy);color:#fff;font-family:inherit;font-size:.95rem;transition:border-color .15s ease;
}
.gb-comments-form input:focus,.gb-comments-form textarea:focus{outline:none;border-color:var(--gb-purple);box-shadow:0 0 0 3px rgba(124,58,237,.15)}
.gb-comments-form textarea{min-height:140px;resize:vertical}

@media (max-width:600px){
  .gb-article{padding:24px}
  .gb-article-thumb{margin:0 -24px 22px}
}
