@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@300;400;600;700;900&family=Playfair+Display:wght@700;900&display=swap');
:root {
  --bg-primary: #f0faf0; --bg-secondary: #ffffff; --bg-card: rgba(255,255,255,0.92);
  --bg-glass: rgba(16,185,129,0.06); --text-primary: #1a2e1a; --text-secondary: #4a6741;
  --text-muted: #7a9a70; --accent: #10b981; --accent-light: #34d399; --accent-dark: #059669;
  --gradient-1: linear-gradient(135deg,#10b981 0%,#059669 100%);
  --gradient-2: linear-gradient(135deg,#f59e0b 0%,#ef4444 100%);
  --gradient-3: linear-gradient(135deg,#10b981 0%,#3b82f6 100%);
  --border: rgba(16,185,129,0.12); --shadow: 0 8px 32px rgba(0,0,0,0.06);
  --radius: 16px; --radius-sm: 10px; --transition: 0.3s cubic-bezier(0.4,0,0.2,1);
  --max-width: 1280px; --header-h: 72px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Nunito',sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.8;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::before{content:'';position:fixed;top:-30%;left:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(16,185,129,0.1) 0%,transparent 70%);z-index:-1;animation:pulse1 15s ease-in-out infinite alternate}
body::after{content:'';position:fixed;bottom:-20%;right:-15%;width:500px;height:500px;background:radial-gradient(circle,rgba(52,211,153,0.08) 0%,transparent 70%);z-index:-1;animation:pulse2 20s ease-in-out infinite alternate}
@keyframes pulse1{0%{transform:translate(0,0) scale(1)}100%{transform:translate(60px,40px) scale(1.1)}}
@keyframes pulse2{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-40px,-30px) scale(1.15)}}
a{color:var(--accent-dark);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--accent)}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--max-width);margin:0 auto;padding:0 24px}
.site-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);background:rgba(255,255,255,0.92);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:1000;box-shadow:0 2px 20px rgba(0,0,0,0.04)}
.header-inner{max-width:var(--max-width);margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between}
.site-logo{display:flex;align-items:center;gap:12px}
.site-logo img{height:72px !important;width:auto !important;max-width:none;filter:drop-shadow(0 2px 4px rgba(16,185,129,0.3))}
.logo-text-group{display:flex;flex-direction:column;line-height:1.2}
.site-logo span:first-child{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:900;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.header-tagline{font-size:0.55rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px}
.main-nav{display:flex;align-items:center;gap:4px}
.main-nav a{padding:8px 14px;border-radius:var(--radius-sm);font-size:0.88rem;font-weight:600;color:var(--text-secondary);transition:var(--transition)}
.main-nav a:hover,.main-nav a.active{color:var(--accent-dark);background:var(--bg-glass)}
.nav-dropdown{position:relative;display:inline-flex;align-items:center}
.dropdown-menu,.nav-dropdown-content{display:none;position:absolute;top:100%;left:0;background:#fff;min-width:200px;box-shadow:0 12px 40px rgba(0,0,0,0.1);border:1px solid var(--border);border-radius:var(--radius-sm);z-index:2000;flex-direction:column;padding:8px 0}
.nav-dropdown:hover .dropdown-menu,.nav-dropdown:hover .nav-dropdown-content{display:flex}
.dropdown-menu a,.nav-dropdown-content a{padding:10px 20px!important;border-radius:0!important;font-size:0.86rem!important;white-space:nowrap}
.dropdown-menu a:hover,.nav-dropdown-content a:hover{background:var(--bg-glass)!important}
.menu-toggle{display:none;background:none;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:8px}
.mobile-nav{display:none;position:fixed;top:var(--header-h);left:0;right:0;bottom:0;background:rgba(255,255,255,0.98);backdrop-filter:blur(20px);z-index:999;padding:24px;overflow-y:auto}
.mobile-nav.open{display:flex;flex-direction:column;gap:4px}
.mobile-nav a{color:var(--text-secondary);padding:14px 20px;border-radius:var(--radius-sm);font-size:1.05rem;font-weight:600}
.mobile-nav a:hover{background:var(--bg-glass);color:var(--accent-dark)}
.hero-section{padding:calc(var(--header-h) + 24px) 0 20px}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:8px;height:480px;border-radius:var(--radius);overflow:hidden}
.hero-card{position:relative;overflow:hidden;display:block;cursor:pointer;border-radius:4px}
.hero-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}
.hero-card:hover img{transform:scale(1.05)}
.hero-card-large{grid-row:1/3;border-radius:var(--radius) 0 0 var(--radius)}
.hero-overlay{position:absolute;bottom:0;left:0;right:0;padding:24px;background:linear-gradient(0deg,rgba(0,0,0,0.85) 0%,rgba(0,0,0,0.4) 60%,transparent 100%);color:#fff;display:flex;flex-direction:column;justify-content:flex-end}
.hero-cat{display:inline-block;background:var(--accent);color:#fff;padding:4px 12px;border-radius:4px;font-size:0.7rem;font-weight:700;text-transform:uppercase;width:fit-content;margin-bottom:10px}
.hero-overlay h2,.hero-overlay h3{font-family:'Playfair Display',serif;font-weight:700;line-height:1.3;color:#fff;margin-bottom:6px;text-shadow:0 2px 6px rgba(0,0,0,0.5)}
.hero-overlay h2{font-size:1.6rem}
.hero-overlay h3{font-size:1rem}
.hero-meta{font-size:0.8rem;opacity:0.85}
.hero-stack{display:contents}
.hero-card-small:first-child{border-radius:0 var(--radius) 0 0}
.hero-card-small:last-child{border-radius:0 0 var(--radius) 0}
.section{padding:50px 0}
.section-title{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700;margin-bottom:6px;color:var(--accent-dark)}
.section-subtitle{color:var(--text-muted);font-size:0.92rem;margin-bottom:32px}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.blog-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:var(--transition);cursor:pointer;box-shadow:var(--shadow)}
.blog-card:hover{transform:translateY(-6px);border-color:var(--accent);box-shadow:0 16px 40px rgba(16,185,129,0.12)}
.card-image{position:relative;height:200px;overflow:hidden}
.card-image img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}
.blog-card:hover .card-image img{transform:scale(1.05)}
.card-category{position:absolute;top:12px;left:12px;padding:4px 12px;border-radius:50px;font-size:0.72rem;font-weight:700;background:var(--accent);color:#fff;backdrop-filter:blur(8px);z-index:2}
.card-body{padding:20px}
.card-body h3{font-size:1.05rem;font-weight:700;line-height:1.5;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-body .excerpt{font-size:0.88rem;color:var(--text-secondary);line-height:1.7;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:16px}
.card-meta{display:flex;justify-content:space-between;font-size:0.8rem;color:var(--text-muted);padding-top:14px;border-top:1px solid var(--border)}
.new-badge{background:var(--gradient-2);color:#fff;padding:2px 10px;border-radius:50px;font-size:0.68rem;font-weight:800;margin-left:6px;vertical-align:middle}
.featured-card{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr;min-height:340px}
.featured-card .card-image{height:100%;min-height:280px}
.featured-card .card-body{display:flex;flex-direction:column;justify-content:center;padding:36px}
.featured-card .card-body h3{font-size:1.4rem;-webkit-line-clamp:3}
.newsletter-section{background:var(--gradient-1);border-radius:var(--radius);padding:48px 40px;text-align:center;color:#fff;margin:40px 0}
.newsletter-section h2{font-family:'Playfair Display',serif;font-size:1.8rem;margin-bottom:10px}
.newsletter-section p{opacity:0.9;margin-bottom:24px;font-size:0.95rem}
.newsletter-form{display:flex;max-width:500px;margin:0 auto;gap:0;border-radius:50px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,0.15)}
.newsletter-form input{flex:1;padding:14px 24px;border:none;font-size:0.95rem;font-family:inherit;outline:none}
.newsletter-form button{padding:14px 28px;background:#fff;color:var(--accent-dark);border:none;font-weight:700;font-size:0.95rem;cursor:pointer;font-family:inherit;transition:var(--transition)}
.newsletter-form button:hover{background:#f0fdf4}
.category-header{padding:calc(var(--header-h) + 40px) 0 30px;text-align:center}
.category-header h1{font-family:'Playfair Display',serif;font-size:2.4rem;margin-bottom:10px;color:var(--accent-dark)}
.category-nav{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:40px}
.category-nav a{padding:8px 20px;border-radius:50px;font-size:0.88rem;font-weight:600;background:var(--bg-secondary);border:1px solid var(--border);transition:var(--transition)}
.category-nav a:hover,.category-nav a.active{background:var(--gradient-1);border-color:transparent;color:#fff;box-shadow:0 6px 18px rgba(16,185,129,0.25);transform:translateY(-2px)}
.article-header{max-width:800px;margin:0 auto 36px;text-align:center;padding-top:calc(var(--header-h) + 36px)}
.article-header h1{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,4vw,2.4rem);line-height:1.4;margin-bottom:16px}
.breadcrumb{display:flex;align-items:center;justify-content:center;gap:8px;font-size:0.85rem;color:var(--text-muted);margin-bottom:20px;flex-wrap:wrap}
.breadcrumb a{color:var(--accent)}
.article-meta{display:flex;align-items:center;justify-content:center;gap:20px;font-size:0.88rem;color:var(--text-secondary);flex-wrap:wrap}
.article-featured-img{max-width:900px;margin:0 auto 40px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.article-featured-img img{width:100%;height:auto}
.article-content{max-width:760px;margin:0 auto;font-size:1.05rem;line-height:2;color:var(--text-primary)}
.article-content h2{font-family:'Playfair Display',serif;font-size:1.5rem;margin:44px 0 16px;padding-bottom:8px;border-bottom:2px solid var(--border);color:var(--accent-dark)}
.article-content h3{font-size:1.2rem;margin:28px 0 12px;color:var(--text-primary)}
.article-content p{margin-bottom:20px}
.article-content blockquote{border-left:4px solid var(--accent);padding:16px 24px;margin:24px 0;background:var(--bg-glass);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-style:italic;color:var(--text-secondary)}
.article-content ul,.article-content ol{margin:16px 0;padding-left:28px}
.article-content li{margin-bottom:8px}
.article-content table{width:100%;border-collapse:collapse;margin:24px 0;background:#fff;border-radius:var(--radius-sm);overflow:hidden}
.article-content th,.article-content td{padding:12px 16px;border:1px solid var(--border);text-align:left}
.article-content th{background:var(--bg-glass);font-weight:700}
.article-content a{color:var(--accent-dark);text-decoration:underline}
.toc-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:24px 28px;margin:0 0 36px}
.toc-container h3{font-size:1.1rem;margin-bottom:12px;color:var(--accent-dark)}
.toc-list{list-style:none;padding:0}
.toc-list li{padding:5px 0}
.toc-list li a{color:var(--text-secondary);font-size:0.92rem}
.toc-list li a:hover{color:var(--accent)}
.article-tags{max-width:800px;margin:36px auto 0;display:flex;flex-wrap:wrap;gap:8px}
.article-tags span{padding:6px 16px;border-radius:50px;font-size:0.82rem;background:var(--bg-glass);border:1px solid var(--border);color:var(--text-secondary)}
.social-share{max-width:800px;margin:28px auto;display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.share-btn{padding:10px 20px;border-radius:50px;font-weight:600;font-size:0.88rem;color:#fff!important;background:#1DA1F2;transition:var(--transition)}
.share-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,0.2)}
.author-box{max-width:800px;margin:36px auto;display:flex;gap:20px;padding:28px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius)}
.author-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;flex-shrink:0;border:3px solid var(--accent)}
.author-info h4{font-size:1.05rem;margin-bottom:6px}
.author-info p{font-size:0.9rem;color:var(--text-secondary);line-height:1.6}
.content-with-sidebar{display:grid;grid-template-columns:1fr 300px;gap:36px;align-items:start}
.sidebar{position:sticky;top:calc(var(--header-h) + 20px)}
.sidebar-widget{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px}
.sidebar-widget h3{font-size:0.95rem;font-weight:700;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.sidebar-widget .popular-post{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);cursor:pointer}
.sidebar-widget .popular-post:last-child{border-bottom:none}
.sidebar-widget .popular-post .thumb{width:60px;height:60px;border-radius:8px;overflow:hidden;flex-shrink:0}
.sidebar-widget .popular-post .thumb img{width:100%;height:100%;object-fit:cover}
.sidebar-widget .popular-post .info h4{font-size:0.82rem;font-weight:600;line-height:1.4}
.sidebar-widget .popular-post .info .meta{font-size:0.72rem;color:var(--text-muted);margin-top:4px}
.pagination{display:flex;justify-content:center;gap:6px;margin-top:36px;flex-wrap:wrap}
.pagination button{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);padding:10px 16px;border-radius:50px;cursor:pointer;font-weight:600;transition:var(--transition);font-family:inherit}
.pagination button:hover,.pagination button.active{background:var(--gradient-1);border-color:transparent;color:#fff;box-shadow:0 4px 14px rgba(16,185,129,0.25)}
.scroll-top{position:fixed;bottom:28px;right:28px;width:46px;height:46px;border-radius:50%;background:var(--gradient-1);border:none;color:#fff;font-size:1.3rem;cursor:pointer;z-index:999;opacity:0;transform:translateY(20px);transition:var(--transition);box-shadow:0 6px 20px rgba(16,185,129,0.35)}
.scroll-top.visible{opacity:1;transform:translateY(0)}
.site-footer{background:#064e3b;border-top:1px solid rgba(255,255,255,0.1);padding:60px 0 30px;margin-top:80px;color:#d1fae5}
.footer-grid{display:grid;grid-template-columns:2fr 1.5fr 1.5fr;gap:50px;margin-bottom:50px}
.footer-grid-new{grid-template-columns:1.2fr 1.5fr 1fr}
.footer-col h3{font-family:'Playfair Display',serif;font-size:1.1rem;margin-bottom:20px;color:#fff;border-bottom:2px solid var(--accent);padding-bottom:10px;display:inline-block}
.footer-about-text{color:#a7f3d0;line-height:1.8;margin:16px 0;font-size:0.88rem}
.footer-contact{font-size:0.85rem;color:#a7f3d0}
.footer-contact a{color:var(--accent-light);font-weight:600}
.footer-col p{font-size:0.85rem;color:#a7f3d0;line-height:1.7}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:6px}
.footer-col ul a{color:#a7f3d0;font-size:0.85rem}
.footer-col ul a:hover{color:#fff}
.fp-item{display:flex;gap:14px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.08);cursor:pointer}
.fp-item img{width:72px;height:54px;border-radius:6px;object-fit:cover}
.fp-item h4{font-size:0.85rem;font-weight:500;color:#d1fae5;line-height:1.4;transition:var(--transition)}
.fp-item:hover h4{color:#fff}
.footer-links-bar{display:flex;justify-content:center;gap:28px;margin-bottom:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,0.08)}
.footer-links-bar a{color:#6ee7b7;font-size:0.85rem}
.footer-links-bar a:hover{color:#fff}
.footer-bottom{text-align:center;color:#6ee7b7;font-size:0.85rem}
/* Latest Articles Section */
.latest-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.latest-cards{display:flex;flex-direction:column;gap:14px}
.latest-card{position:relative;border-radius:var(--radius-sm);overflow:hidden;height:200px;cursor:pointer;background-size:cover;background-position:center}
.latest-card-overlay{position:absolute;inset:0;padding:20px;background:linear-gradient(0deg,rgba(0,0,0,0.85) 0%,rgba(0,0,0,0.2) 60%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;color:#fff}
.latest-card-overlay h3{font-size:0.95rem;font-weight:700;color:#fff;line-height:1.35;text-shadow:0 1px 4px rgba(0,0,0,0.3)}
.latest-list{display:flex;flex-direction:column}
.latest-list-item{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:var(--transition);align-items:center}
.latest-list-item:hover{padding-left:6px;background:var(--bg-glass);border-radius:6px}
.latest-list-item img{width:80px;height:60px;object-fit:cover;border-radius:8px;flex-shrink:0}
.latest-list-item h4{font-size:0.88rem;font-weight:600;line-height:1.4;color:var(--text-primary)}
.latest-list-item div{display:flex;flex-direction:column;gap:4px}
.latest-list-meta{font-size:0.75rem;color:var(--text-muted)}
/* Category Spotlight */
.cat-spotlight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.spotlight-col{border-top:3px solid var(--accent);padding-top:16px}
.spotlight-title{font-family:'Playfair Display',serif;font-size:0.95rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;margin-bottom:18px;text-align:center;color:var(--accent-dark)}
.spotlight-featured{position:relative;border-radius:var(--radius-sm);overflow:hidden;height:210px;cursor:pointer;margin-bottom:14px;background-size:cover;background-position:center}
.spotlight-overlay{position:absolute;inset:0;padding:16px;background:linear-gradient(0deg,rgba(0,0,0,0.85) 0%,rgba(0,0,0,0.2) 60%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;color:#fff}
.spotlight-overlay h4{font-family:'Playfair Display',serif;font-size:0.92rem;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,0.3)}
.spotlight-list-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:var(--transition);align-items:center}
.spotlight-list-item:hover{padding-left:6px;background:var(--bg-glass);border-radius:6px}
.spotlight-list-item img{width:65px;height:48px;object-fit:cover;border-radius:6px;flex-shrink:0}
.spotlight-list-item span{font-size:0.82rem;font-weight:600;color:var(--text-primary);line-height:1.4}
/* Bottom Banner */
.bottom-banner-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.banner-card{position:relative;border-radius:var(--radius);overflow:hidden;height:240px;display:block;background-size:cover;background-position:center}
.banner-overlay{position:absolute;inset:0;padding:24px;background:linear-gradient(0deg,rgba(0,0,0,0.85) 0%,rgba(0,0,0,0.2) 50%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;align-items:center;text-align:center;color:#fff}
.banner-overlay h3{font-family:'Playfair Display',serif;font-size:0.95rem;font-weight:800;text-transform:uppercase;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,0.4);line-height:1.35}
@media(max-width:1024px){
  .main-nav{display:none}.menu-toggle{display:block}
  .content-with-sidebar{grid-template-columns:1fr}.sidebar{display:none}
  .footer-grid,.footer-grid-new{grid-template-columns:1fr;gap:36px}
}
@media(max-width:768px){
  .hero-grid{grid-template-columns:1fr;grid-template-rows:280px 200px 200px;height:auto}
  .hero-card-large{grid-row:auto;border-radius:var(--radius) var(--radius) 0 0}
  .hero-card-small:first-child{border-radius:0!important}
  .hero-card-small:last-child{border-radius:0 0 var(--radius) var(--radius)!important}
  .blog-grid{grid-template-columns:1fr}
  .featured-card{grid-template-columns:1fr}
  .featured-card .card-image{min-height:200px}
  .author-box{flex-direction:column;align-items:center;text-align:center}
  .newsletter-form{flex-direction:column;border-radius:var(--radius)}
  .newsletter-form input,.newsletter-form button{border-radius:50px}
  .latest-grid{grid-template-columns:1fr}
  .cat-spotlight-grid{grid-template-columns:1fr;gap:36px}
  .bottom-banner-grid{grid-template-columns:1fr}
  .banner-card{height:200px}
}

/* ===== SEARCH OVERLAY ===== */
.nav-search {
  display: inline-flex;
  align-items: center;
  padding: 8px;
  cursor: pointer;
  color: var(--text-primary, #333);
  font-size: 1.1rem;
  transition: 0.3s ease;
}
.nav-search:hover {
  opacity: 0.7;
  transform: scale(1.1);
}

.search-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.85);
  backdrop-filter: blur(12px);
  z-index: 9999;
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding-top: 10vh;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.search-overlay.active {
  display: flex;
  opacity: 1;
}

.search-overlay-inner {
  width: 90%;
  max-width: 720px;
  position: relative;
}

.search-close {
  position: absolute;
  top: -48px;
  right: 0;
  background: none;
  border: none;
  color: #fff;
  font-size: 2.2rem;
  cursor: pointer;
  opacity: 0.7;
  transition: 0.3s ease;
  line-height: 1;
}
.search-close:hover { opacity: 1; transform: scale(1.15); }

.search-box {
  position: relative;
}
.search-box input {
  width: 100%;
  padding: 18px 24px 18px 54px;
  font-size: 1.15rem;
  font-family: inherit;
  border: none;
  border-radius: 12px;
  background: #fff;
  color: #1a1a1a;
  box-shadow: 0 10px 40px rgba(0,0,0,0.3);
  outline: none;
}
.search-box input::placeholder {
  color: #aaa;
  font-style: italic;
}
.search-box::before {
  content: '🔍';
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.2rem;
  pointer-events: none;
}

.search-results {
  margin-top: 20px;
  max-height: 55vh;
  overflow-y: auto;
  padding-right: 4px;
}
.search-results::-webkit-scrollbar { width: 6px; }
.search-results::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.2); border-radius: 3px; }

.search-hint {
  color: rgba(255,255,255,0.5);
  text-align: center;
  font-size: 0.95rem;
  padding: 40px 0;
  font-style: italic;
}
.search-no-results {
  color: rgba(255,255,255,0.6);
  text-align: center;
  padding: 40px 0;
  font-size: 1rem;
}

.search-result-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 16px;
  background: rgba(255,255,255,0.08);
  border-radius: 10px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: 0.3s ease;
  border: 1px solid rgba(255,255,255,0.06);
}
.search-result-item:hover {
  background: rgba(255,255,255,0.15);
  transform: translateX(4px);
  border-color: rgba(255,255,255,0.12);
}

.search-result-img {
  width: 72px;
  height: 54px;
  object-fit: cover;
  border-radius: 6px;
  flex-shrink: 0;
}
.search-result-info {
  flex: 1;
  min-width: 0;
}
.search-result-cat {
  display: inline-block;
  font-size: 0.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #c4975a;
  margin-bottom: 4px;
}
.search-result-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.search-result-excerpt {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.5);
  margin-top: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.search-count {
  color: rgba(255,255,255,0.4);
  font-size: 0.8rem;
  padding: 8px 0 4px;
  text-align: right;
}

@media (max-width: 768px) {
  .search-overlay { padding-top: 5vh; }
  .search-overlay-inner { width: 95%; }
  .search-box input { font-size: 1rem; padding: 16px 20px 16px 46px; }
  .search-result-img { width: 60px; height: 44px; }
}

.logo-text-group span:first-child{font-weight:900;font-size:1.4rem;letter-spacing:1px;color:var(--text-primary);}
.logo-text-group .header-tagline{font-size:0.85rem;color:var(--text-muted);font-weight:400;}
/* ===== DAILY WELLNESS SCORE WIDGET ===== */
.wellness-score-section { padding: 30px 0 40px; }
.ws-card {
  background: linear-gradient(135deg, #064e3b 0%, #065f46 40%, #047857 100%);
  border-radius: 20px;
  padding: 40px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,0.25);
  border: 1px solid rgba(52,211,153,0.2);
}
.ws-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, #34d399, #a78bfa, #f472b6);
}
.ws-card::after {
  content: '';
  position: absolute;
  top: -50%; right: -15%;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(52,211,153,0.1) 0%, transparent 60%);
  pointer-events: none;
}
.ws-header { text-align: center; margin-bottom: 32px; position: relative; z-index: 1; }
.ws-emoji { font-size: 3rem; display: block; margin-bottom: 8px; animation: ws-pulse 2s ease-in-out infinite; }
@keyframes ws-pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.15)} }
.ws-header h2 {
  font-size: 2rem; font-weight: 800; margin-bottom: 8px;
  background: linear-gradient(135deg, #6ee7b7, #a78bfa);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.ws-header p { font-size: 0.95rem; color: rgba(255,255,255,0.55); }
.ws-body { position: relative; z-index: 1; min-height: 160px; }
.ws-step { display: none; animation: ws-fadeIn 0.4s ease; }
.ws-step.active { display: block; }
.ws-step.done { display: none; }
@keyframes ws-fadeIn { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }
.ws-step h3 { text-align: center; color: #fff; font-size: 1.3rem; font-weight: 600; margin-bottom: 20px; }
.ws-options { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; max-width: 800px; margin: 0 auto; }
.ws-opt {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 20px 10px; border-radius: 16px;
  border: 2px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.06);
  backdrop-filter: blur(6px); cursor: pointer;
  transition: all 0.3s ease; color: #fff;
  font-family: inherit;
}
.ws-opt:hover {
  background: rgba(52,211,153,0.15);
  border-color: rgba(52,211,153,0.4);
  transform: translateY(-4px);
  box-shadow: 0 8px 25px rgba(52,211,153,0.15);
}
.ws-opt.selected {
  background: linear-gradient(135deg, rgba(52,211,153,0.4), rgba(167,139,246,0.3));
  border-color: #34d399; transform: scale(1.05);
  box-shadow: 0 8px 30px rgba(52,211,153,0.3);
}
.ws-opt.faded { opacity: 0.2; pointer-events: none; transform: scale(0.95); }
.ws-opt-icon { font-size: 2rem; line-height: 1; }
.ws-opt-label { font-weight: 600; font-size: 0.82rem; text-align: center; line-height: 1.3; }
.ws-progress { height: 5px; background: rgba(255,255,255,0.08); border-radius: 3px; margin-top: 24px; overflow: hidden; }
.ws-progress-bar {
  height: 100%; background: linear-gradient(90deg, #34d399, #6ee7b7);
  border-radius: 3px; transition: width 0.5s ease;
  box-shadow: 0 0 12px rgba(52,211,153,0.5);
}
/* Result */
.ws-score-hero { text-align: center; margin-bottom: 24px; }
.ws-score-ring {
  width: 140px; height: 140px; border-radius: 50%; margin: 0 auto 12px;
  background: conic-gradient(var(--score-color) var(--score-pct), rgba(255,255,255,0.08) var(--score-pct));
  display: flex; align-items: center; justify-content: center;
  animation: ws-ringIn 0.8s ease forwards;
}
@keyframes ws-ringIn { from{transform:scale(0.5);opacity:0} to{transform:scale(1);opacity:1} }
.ws-score-inner {
  width: 110px; height: 110px; border-radius: 50%;
  background: #064e3b; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
}
.ws-score-num { font-size: 2.5rem; font-weight: 900; color: #fff; line-height: 1; }
.ws-score-label { font-size: 0.75rem; color: rgba(255,255,255,0.4); }
.ws-grade { font-size: 1.4rem; font-weight: 800; margin-top: 8px; }
.ws-breakdown { max-width: 500px; margin: 0 auto 20px; }
.ws-cat-row { display: grid; grid-template-columns: 100px 1fr 40px; gap: 10px; align-items: center; margin-bottom: 8px; }
.ws-cat-name { font-size: 0.8rem; color: rgba(255,255,255,0.7); font-weight: 600; }
.ws-cat-bar-track { height: 10px; background: rgba(255,255,255,0.08); border-radius: 5px; overflow: hidden; }
.ws-cat-bar { height: 100%; border-radius: 5px; transition: width 0.6s ease; min-width: 4px; }
.ws-cat-pct { font-size: 0.75rem; color: rgba(255,255,255,0.5); font-weight: 700; text-align: right; }
.ws-tip {
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px; padding: 16px 20px; margin: 20px auto; max-width: 600px;
  font-size: 0.9rem; color: rgba(255,255,255,0.7); line-height: 1.6; text-align: center;
}
.ws-tip strong { color: #6ee7b7; }
.ws-restart {
  display: block; margin: 20px auto 0; padding: 12px 32px;
  border: 2px solid rgba(52,211,153,0.3); background: rgba(52,211,153,0.08);
  color: #6ee7b7; font-family: inherit; font-size: 0.95rem; font-weight: 600;
  border-radius: 50px; cursor: pointer; transition: all 0.3s ease;
}
.ws-restart:hover { background: rgba(52,211,153,0.2); border-color: #34d399; transform: translateY(-2px); color: #fff; }
@media (max-width: 768px) {
  .ws-card { padding: 24px 16px; }
  .ws-options { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .ws-opt { padding: 14px 8px; }
  .ws-opt-icon { font-size: 1.6rem; }
  .ws-header h2 { font-size: 1.5rem; }
  .ws-score-ring { width: 120px; height: 120px; }
  .ws-score-inner { width: 95px; height: 95px; }
  .ws-score-num { font-size: 2rem; }
}
