/*
Theme Name: Ultimate Design Hub
Theme URI: https://ultimatedesignhub.com
Author: Ultimate Design Hub
Description: A professional dark blue digital agency theme with full Customizer support, enhanced blog with category filters, featured posts, and sidebar widgets.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: ultimate-design-hub
Tags: blog, portfolio, agency, dark, business, customizer, full-width-template
*/

/* =============================================
   CSS CUSTOM PROPERTIES
   ============================================= */
:root {
  --navy:        #050d1f;
  --navy2:       #0a1830;
  --navy3:       #0f2347;
  --navy4:       #162d5a;
  --blue:        #1a4db5;
  --blue-mid:    #2563eb;
  --blue-light:  #3b82f6;
  --blue-glow:   #60a5fa;
  --cyan:        #06d6f5;
  --cyan-dim:    rgba(6,214,245,0.12);
  --gold:        #f5c518;
  --white:       #f0f4ff;
  --white-dim:   rgba(240,244,255,0.6);
  --white-faint: rgba(240,244,255,0.2);
  --white-ghost: rgba(240,244,255,0.06);
  --border:      rgba(99,160,255,0.15);
  --border-glow: rgba(99,160,255,0.35);
  --radius:      20px;
  --font-d: 'Bebas Neue', sans-serif;
  --font-b: 'Outfit', sans-serif;
}

/* =============================================
   RESET & BASE
   ============================================= */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-b);background:var(--navy);color:var(--white);overflow-x:hidden;line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button,input,textarea,select{font-family:inherit}
h1,h2,h3,h4,h5,h6{line-height:1.15}

/* GRAIN */
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* =============================================
   UTILITIES
   ============================================= */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 5vw}
.section-pad{padding:7rem 0}
.text-center{text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border-glow);background:var(--white-ghost);font-size:.72rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);padding:.45rem 1rem;border-radius:100px;margin-bottom:1.25rem}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--cyan);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.section-tag{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan);margin-bottom:.75rem}
.section-title{font-family:var(--font-d);font-size:clamp(2.2rem,4vw,3.8rem);letter-spacing:.04em;color:var(--white);margin-bottom:1rem}
.section-sub{font-size:1rem;color:var(--white-dim);line-height:1.75;max-width:55ch;margin-bottom:3rem}
.section-sub.centered{margin-left:auto;margin-right:auto}

/* BUTTONS */
.btn-glow{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--blue-mid),var(--blue-light));color:#fff;padding:.9rem 2rem;border-radius:100px;font-size:.95rem;font-weight:600;box-shadow:0 0 30px rgba(37,99,235,.45);transition:all .25s}
.btn-glow:hover{box-shadow:0 0 50px rgba(37,99,235,.7);transform:translateY(-2px);color:#fff}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:var(--white-ghost);color:var(--white);padding:.9rem 2rem;border-radius:100px;border:1px solid var(--border-glow);font-size:.95rem;font-weight:500;transition:all .25s}
.btn-ghost:hover{background:var(--white-faint);border-color:var(--cyan);color:var(--cyan)}

/* FADE-UP */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.fade-up.in{opacity:1;transform:none}

/* =============================================
   NAVIGATION
   ============================================= */
#site-header{position:fixed;top:0;left:0;right:0;z-index:999;background:rgba(5,13,31,.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:background .3s}
#site-header.scrolled{background:rgba(5,13,31,.97)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 5vw}
.site-logo{display:flex;align-items:center;gap:10px;font-family:var(--font-d);font-size:1.55rem;letter-spacing:.06em;color:var(--white)}
.site-logo .logo-mark{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,var(--blue-mid),var(--cyan));display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.site-logo .logo-accent{color:var(--cyan)}
.site-logo img{max-height:40px;width:auto}
#primary-navigation{display:flex;align-items:center;gap:2.5rem}
#primary-navigation ul{display:flex;gap:2.5rem}
#primary-navigation a{font-size:.85rem;font-weight:500;color:var(--white-dim);letter-spacing:.05em;text-transform:uppercase;transition:color .2s}
#primary-navigation a:hover,#primary-navigation .current-menu-item>a{color:var(--cyan)}
#primary-navigation li{position:relative}
#primary-navigation .sub-menu{position:absolute;top:100%;left:0;background:var(--navy2);border:1px solid var(--border);border-radius:12px;padding:.5rem 0;min-width:180px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .25s;pointer-events:none;box-shadow:0 20px 40px rgba(0,0,0,.4)}
#primary-navigation li:hover .sub-menu{opacity:1;visibility:visible;transform:none;pointer-events:all}
#primary-navigation .sub-menu li{display:block}
#primary-navigation .sub-menu a{display:block;padding:.6rem 1.25rem;font-size:.85rem;text-transform:none}
#primary-navigation .sub-menu a:hover{color:var(--cyan);background:var(--white-ghost)}
.nav-cta{background:linear-gradient(135deg,var(--blue-mid),var(--blue-light));color:#fff!important;padding:.6rem 1.5rem;border-radius:100px;font-size:.85rem!important;font-weight:600!important;box-shadow:0 0 20px rgba(37,99,235,.4);transition:all .25s!important;text-transform:none!important;letter-spacing:.03em!important}
.nav-cta:hover{box-shadow:0 0 35px rgba(37,99,235,.7)!important;transform:translateY(-1px)}
.menu-toggle{display:none;background:var(--white-ghost);border:1px solid var(--border);color:var(--white);padding:.5rem .85rem;border-radius:8px;cursor:pointer;font-size:1.1rem;transition:all .2s}

/* =============================================
   PAGE HERO (blog pages)
   ============================================= */
.page-hero{padding:9rem 5vw 5rem;position:relative;overflow:hidden;border-bottom:1px solid var(--border);background:var(--navy2)}
.page-hero::before{content:'';position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.15) 0%,transparent 65%);right:-200px;top:-200px;pointer-events:none}
.page-hero::after{content:'';position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(6,214,245,.08) 0%,transparent 65%);left:5vw;bottom:-150px;pointer-events:none}
.page-hero-inner{position:relative;z-index:1;max-width:1200px;margin:0 auto}
.page-hero h1{font-family:var(--font-d);font-size:clamp(3rem,6vw,6rem);letter-spacing:.04em;line-height:.95;color:var(--white);margin-bottom:1.25rem}
.page-hero h1 span{color:var(--cyan)}
.page-hero p{font-size:1rem;color:var(--white-dim);max-width:52ch;line-height:1.75;margin-bottom:2rem}
.hero-blog-stats{display:flex;gap:3rem;flex-wrap:wrap;margin-bottom:2rem}
.hstat-num{font-family:var(--font-d);font-size:2rem;letter-spacing:.04em;background:linear-gradient(135deg,var(--white),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.hstat-lbl{font-size:.72rem;color:var(--white-dim);letter-spacing:.08em;text-transform:uppercase;margin-top:3px}

/* Search bar in hero */
.hero-search-wrap{display:flex;gap:.75rem;flex-wrap:wrap}
.hero-search-input-wrap{position:relative;flex:1;min-width:240px;max-width:420px}
.hero-search-input-wrap input{width:100%;background:var(--white-ghost);border:1px solid var(--border-glow);border-radius:100px;padding:.85rem 1.25rem .85rem 3rem;color:var(--white);font-size:.9rem;outline:none;font-family:var(--font-b);transition:border-color .2s}
.hero-search-input-wrap input::placeholder{color:rgba(240,244,255,.3)}
.hero-search-input-wrap input:focus{border-color:var(--cyan)}
.search-icon-abs{position:absolute;left:1.1rem;top:50%;transform:translateY(-50%);color:var(--white-dim);pointer-events:none}
.hero-search-btn{background:linear-gradient(135deg,var(--blue-mid),var(--cyan));color:var(--navy);padding:.85rem 1.75rem;border-radius:100px;border:none;font-size:.9rem;font-weight:700;cursor:pointer;font-family:var(--font-b);transition:all .25s;white-space:nowrap}
.hero-search-btn:hover{box-shadow:0 0 25px rgba(6,214,245,.35);transform:translateY(-1px)}

/* =============================================
   BLOG LAYOUT (index, archive)
   ============================================= */
.blog-main-layout{display:grid;grid-template-columns:1fr 300px;gap:3rem;max-width:1200px;margin:0 auto;padding:4rem 5vw 6rem}

/* Category filter */
.cat-filter-bar{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:2.5rem}
.cat-filter-btn{background:var(--white-ghost);border:1px solid var(--border);border-radius:100px;padding:.45rem 1.1rem;font-size:.78rem;font-weight:500;color:var(--white-dim);cursor:pointer;transition:all .2s;letter-spacing:.04em;font-family:var(--font-b)}
.cat-filter-btn:hover,.cat-filter-btn.active{background:var(--cyan-dim);border-color:var(--cyan);color:var(--cyan)}

/* Featured post */
.featured-post-card{background:var(--navy2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:2rem;display:grid;grid-template-columns:1.2fr 1fr;transition:all .35s;position:relative}
.featured-post-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--cyan),transparent)}
.featured-post-card:hover{border-color:rgba(6,214,245,.4);box-shadow:0 20px 50px rgba(0,0,0,.3)}
.feat-thumb{overflow:hidden;position:relative}
.feat-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.featured-post-card:hover .feat-thumb img{transform:scale(1.04)}
.feat-thumb-placeholder{width:100%;height:100%;min-height:280px;display:flex;align-items:center;justify-content:center;font-size:5rem;background:linear-gradient(135deg,#050d1f,#0f2347)}
.feat-badge{position:absolute;top:1rem;left:1rem;background:linear-gradient(135deg,var(--blue-mid),var(--cyan));color:var(--navy);font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .75rem;border-radius:100px}
.feat-body{padding:2.5rem;display:flex;flex-direction:column;justify-content:center}
.post-category-tag{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);margin-bottom:.75rem}
.feat-body h2{font-family:var(--font-d);font-size:clamp(1.4rem,2.5vw,2rem);letter-spacing:.03em;color:var(--white);line-height:1.1;margin-bottom:1rem}
.feat-body h2 a{color:inherit;transition:color .2s}
.feat-body h2 a:hover{color:var(--cyan)}
.post-meta-strip{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}
.meta-pill{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:rgba(240,244,255,.4)}
.feat-excerpt{font-size:.9rem;color:var(--white-dim);line-height:1.75;margin-bottom:1.75rem;flex:1}
.feat-read-btn{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--blue-mid),var(--blue-light));color:#fff;padding:.7rem 1.5rem;border-radius:100px;font-size:.85rem;font-weight:600;transition:all .25s;align-self:flex-start}
.feat-read-btn:hover{box-shadow:0 0 25px rgba(37,99,235,.5);transform:translateY(-2px);color:#fff}

/* Posts grid */
.posts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
.blog-card{background:var(--navy2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .35s;display:flex;flex-direction:column;position:relative}
.blog-card:hover{border-color:rgba(6,214,245,.4);transform:translateY(-5px);box-shadow:0 20px 50px rgba(0,0,0,.3)}
.blog-card-thumb{overflow:hidden;position:relative}
.blog-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s;aspect-ratio:16/9}
.blog-card:hover .blog-card-thumb img{transform:scale(1.06)}
.blog-card-thumb-placeholder{aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;font-size:2.8rem}
.tp1{background:linear-gradient(135deg,#050d1f,#0f2347)}
.tp2{background:linear-gradient(135deg,#0c1a2e,#163052)}
.tp3{background:linear-gradient(135deg,#07131a,#0a2a36)}
.tp4{background:linear-gradient(135deg,#0d0523,#1e0f3c)}
.tp5{background:linear-gradient(135deg,#091a0d,#0e3318)}
.tp6{background:linear-gradient(135deg,#1a0e05,#3a1e08)}
.blog-card-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.blog-card-body h2,.blog-card-body h3{font-size:1rem;font-weight:600;line-height:1.4;color:var(--white);margin-bottom:.6rem}
.blog-card-body h2 a,.blog-card-body h3 a{color:inherit;transition:color .2s}
.blog-card-body h2 a:hover,.blog-card-body h3 a:hover{color:var(--cyan)}
.card-author-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}
.author-av{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--blue-mid),var(--cyan));display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;color:var(--navy);flex-shrink:0}
.author-av img{width:26px;height:26px;border-radius:50%;object-fit:cover}
.author-av-text{font-size:.75rem;color:var(--white-dim)}
.blog-card-excerpt{font-size:.83rem;color:var(--white-dim);line-height:1.65;margin-bottom:1rem;flex:1}
.blog-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:.75rem;border-top:1px solid var(--border)}
.card-date-label{font-size:.72rem;color:rgba(240,244,255,.3);display:flex;align-items:center;gap:.35rem}
.card-read-link{font-size:.78rem;font-weight:600;color:var(--cyan);display:flex;align-items:center;gap:4px;transition:gap .2s}
.card-read-link:hover{gap:8px;color:var(--cyan)}

/* Load more */
.load-more-wrap{margin-top:2.5rem;text-align:center}
.load-more-btn{background:var(--white-ghost);border:1px solid var(--border-glow);color:var(--white);padding:.85rem 2.5rem;border-radius:100px;font-size:.9rem;font-weight:500;cursor:pointer;font-family:var(--font-b);transition:all .25s;display:inline-flex;align-items:center;gap:.5rem}
.load-more-btn:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(6,214,245,.06)}

/* Pagination */
.udh-pagination{display:flex;gap:.5rem;align-items:center;margin-top:3rem;flex-wrap:wrap}
.udh-pagination .page-numbers{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:.875rem;border:1px solid var(--border);color:var(--white-dim);transition:all .2s}
.udh-pagination .page-numbers.current,.udh-pagination .page-numbers:hover{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-dim)}
.udh-pagination .prev,.udh-pagination .next{width:auto;padding:0 1rem}

/* =============================================
   SIDEBAR
   ============================================= */
.blog-sidebar{display:flex;flex-direction:column;gap:1.5rem}
.sidebar-widget{background:var(--navy2);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;transition:border-color .3s;position:relative;overflow:hidden}
.sidebar-widget::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border-glow),transparent)}
.sidebar-widget:hover{border-color:var(--border-glow)}
.widget-title{font-family:var(--font-d);font-size:1.1rem;letter-spacing:.06em;color:var(--white);margin-bottom:1.25rem}
/* widget search */
.widget-search-wrap{position:relative}
.widget-search-wrap input{width:100%;background:var(--navy3);border:1px solid var(--border);border-radius:100px;padding:.75rem 1rem .75rem 2.75rem;color:var(--white);font-size:.875rem;outline:none;font-family:var(--font-b);transition:border-color .2s}
.widget-search-wrap input:focus{border-color:var(--cyan)}
.widget-search-wrap input::placeholder{color:rgba(240,244,255,.25)}
.widget-search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--white-dim);pointer-events:none;font-size:.85rem}
/* category list */
.widget-cat-list li{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid var(--border)}
.widget-cat-list li:last-child{border-bottom:none;padding-bottom:0}
.widget-cat-list a{font-size:.875rem;color:var(--white-dim);transition:color .2s}
.widget-cat-list a:hover{color:var(--cyan)}
.cat-post-count{font-size:.72rem;background:var(--white-ghost);border:1px solid var(--border);color:var(--white-dim);padding:.15rem .5rem;border-radius:100px}
/* recent posts */
.recent-post-item{display:flex;gap:.85rem;padding:.75rem 0;border-bottom:1px solid var(--border)}
.recent-post-item:last-child{border-bottom:none;padding-bottom:0}
.recent-post-thumb{width:56px;height:56px;border-radius:10px;overflow:hidden;flex-shrink:0}
.recent-post-thumb img{width:100%;height:100%;object-fit:cover}
.recent-post-placeholder{width:56px;height:56px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.rph1{background:linear-gradient(135deg,#050d1f,#162d5a)}
.rph2{background:linear-gradient(135deg,#0c1a2e,#1a3a70)}
.rph3{background:linear-gradient(135deg,#07131a,#0a2a36)}
.recent-post-info a{font-size:.82rem;font-weight:500;color:var(--white);line-height:1.4;transition:color .2s;display:block;margin-bottom:.3rem}
.recent-post-info a:hover{color:var(--cyan)}
.recent-post-date{font-size:.72rem;color:rgba(240,244,255,.3)}
/* tags */
.widget-tag-cloud{display:flex;flex-wrap:wrap;gap:.5rem}
.tag-chip{background:var(--white-ghost);border:1px solid var(--border);border-radius:100px;padding:.3rem .85rem;font-size:.75rem;color:var(--white-dim);transition:all .2s}
.tag-chip:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(6,214,245,.08)}
.tag-chip a{color:inherit}
/* newsletter widget */
.widget-nl p{font-size:.83rem;color:var(--white-dim);line-height:1.65;margin-bottom:1rem}
.widget-nl-input{width:100%;background:var(--navy3);border:1px solid var(--border);border-radius:12px;padding:.75rem 1rem;color:var(--white);font-size:.875rem;outline:none;font-family:var(--font-b);margin-bottom:.75rem;transition:border-color .2s}
.widget-nl-input:focus{border-color:var(--cyan)}
.widget-nl-input::placeholder{color:rgba(240,244,255,.25)}
.widget-nl-btn{width:100%;background:linear-gradient(135deg,var(--blue-mid),var(--cyan));color:var(--navy);border:none;border-radius:12px;padding:.8rem;font-size:.875rem;font-weight:700;cursor:pointer;font-family:var(--font-b);transition:all .25s}
.widget-nl-btn:hover{box-shadow:0 0 20px rgba(6,214,245,.3);transform:translateY(-1px)}

/* =============================================
   SINGLE POST
   ============================================= */
.single-post-layout{display:grid;grid-template-columns:2fr 300px;gap:4rem;max-width:1200px;margin:0 auto;padding:5rem 5vw 6rem}
.post-content{font-size:1rem;line-height:1.85;color:var(--white-dim)}
.post-content h1,.post-content h2,.post-content h3,.post-content h4{font-family:var(--font-d);color:var(--white);margin:2rem 0 1rem;letter-spacing:.04em}
.post-content h2{font-size:2rem}
.post-content h3{font-size:1.5rem}
.post-content p{margin-bottom:1.5rem}
.post-content a{color:var(--cyan)}
.post-content a:hover{text-decoration:underline}
.post-content img{border-radius:12px;margin:2rem 0}
.post-content ul,.post-content ol{padding-left:1.5rem;margin-bottom:1.5rem}
.post-content li{margin-bottom:.5rem}
.post-content blockquote{border-left:3px solid var(--cyan);padding:1rem 1.5rem;background:var(--white-ghost);border-radius:0 12px 12px 0;margin:2rem 0;font-style:italic}
.post-content pre{background:var(--navy3);border:1px solid var(--border);border-radius:12px;padding:1.5rem;overflow-x:auto;margin:2rem 0}
.post-content code{font-family:monospace;font-size:.9em;background:var(--white-ghost);padding:.15em .4em;border-radius:4px}
.post-meta-bar{display:flex;align-items:center;gap:1.5rem;font-size:.82rem;color:var(--white-dim);margin-bottom:2rem;flex-wrap:wrap;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.post-meta-bar a{color:var(--cyan)}
.post-featured-image{border-radius:var(--radius);overflow:hidden;margin-bottom:2.5rem;border:1px solid var(--border)}
.post-featured-image img{width:100%}
.post-tags{margin-top:2rem;display:flex;gap:.5rem;flex-wrap:wrap}
.post-nav{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border)}

/* =============================================
   HOMEPAGE SECTIONS
   ============================================= */
.hero-section{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;align-items:center;gap:3rem;padding:9rem 5vw 5rem;position:relative;overflow:hidden}
.hero-section::before{content:'';position:absolute;width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.18) 0%,transparent 65%);right:-200px;top:-200px;pointer-events:none}
.hero-section::after{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(6,214,245,.1) 0%,transparent 65%);left:10vw;bottom:-100px;pointer-events:none}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border-glow);background:var(--white-ghost);font-size:.75rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);padding:.5rem 1.1rem;border-radius:100px;margin-bottom:1.75rem}
.hero-title{font-family:var(--font-d);font-size:clamp(3.2rem,6vw,6.5rem);line-height:.95;letter-spacing:.04em;color:var(--white);margin-bottom:1.75rem}
.hero-title .accent{color:var(--cyan);display:block}
.hero-desc{font-size:1rem;line-height:1.8;color:var(--white-dim);max-width:46ch;margin-bottom:2.5rem}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
.hero-visual{position:relative}
.hero-card{background:var(--navy2);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;box-shadow:0 30px 80px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.05);position:relative;overflow:hidden;animation:floatCard 5s ease-in-out infinite}
@keyframes floatCard{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.hero-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent)}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.75rem}
.card-label-sm{font-size:.72rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--white-dim)}
.live-badge{display:flex;align-items:center;gap:5px;font-size:.7rem;font-weight:600;color:#4ade80;background:rgba(74,222,128,.1);border:1px solid rgba(74,222,128,.25);padding:.25rem .75rem;border-radius:100px}
.live-dot{width:5px;height:5px;background:#4ade80;border-radius:50%;animation:blink 1.5s infinite}
.metric-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.75rem}
.metric-box{background:var(--white-ghost);border:1px solid var(--border);border-radius:12px;padding:1rem}
.metric-val{font-family:var(--font-d);font-size:1.9rem;letter-spacing:.04em;color:var(--white);line-height:1}
.metric-val.cyan{color:var(--cyan)}
.metric-val.gold{color:var(--gold)}
.metric-lbl{font-size:.72rem;color:var(--white-dim);margin-top:4px}
.bar-list{display:flex;flex-direction:column;gap:.85rem}
.bar-item{display:flex;flex-direction:column;gap:5px}
.bar-info{display:flex;justify-content:space-between;font-size:.78rem}
.bar-info .lbl{color:var(--white-dim)}
.bar-info .val{color:var(--white);font-weight:500}
.bar-track{height:5px;background:var(--white-ghost);border-radius:3px;overflow:hidden}
.bar-fill{height:100%;border-radius:3px}
.fill-cyan{background:linear-gradient(90deg,var(--blue-mid),var(--cyan))}
.fill-blue{background:linear-gradient(90deg,var(--navy4),var(--blue-light))}
.fill-gold{background:linear-gradient(90deg,#b45309,var(--gold))}
.float-chip{position:absolute;background:var(--navy2);border:1px solid var(--border-glow);border-radius:14px;padding:.7rem 1rem;font-size:.8rem;font-weight:500;color:var(--white);box-shadow:0 8px 30px rgba(0,0,0,.3);display:flex;align-items:center;gap:8px;white-space:nowrap}
.float-chip.tl{top:-1.2rem;left:-2rem;animation:floatCard 4s ease-in-out infinite reverse}
.float-chip.br{bottom:-1.2rem;right:-1.5rem;animation:floatCard 6s ease-in-out infinite}

/* Stats band */
.stats-band{background:var(--navy2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:3.5rem 5vw;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-cell{text-align:center;border-right:1px solid var(--border);padding:0 1rem}
.stat-cell:last-child{border-right:none}
.stat-num{font-family:var(--font-d);font-size:3.2rem;letter-spacing:.04em;background:linear-gradient(135deg,var(--white),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.stat-lbl{font-size:.78rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--white-dim);margin-top:6px}

/* Services */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.service-card{background:var(--navy2);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;transition:all .35s;position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(37,99,235,.06),rgba(6,214,245,.04));opacity:0;transition:opacity .35s}
.service-card:hover{border-color:rgba(6,214,245,.4);transform:translateY(-5px);box-shadow:0 20px 50px rgba(0,0,0,.3),0 0 30px rgba(6,214,245,.08)}
.service-card:hover::before{opacity:1}
.service-num{font-family:var(--font-d);font-size:.95rem;letter-spacing:.1em;color:var(--blue-glow);margin-bottom:1.25rem;opacity:.5}
.service-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--navy3),var(--navy4));border:1px solid var(--border-glow);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:1.25rem;transition:box-shadow .3s}
.service-card:hover .service-icon{box-shadow:0 0 20px rgba(6,214,245,.2)}
.service-card h3{font-size:1.1rem;font-weight:600;color:var(--white);margin-bottom:.65rem}
.service-card p{font-size:.875rem;color:var(--white-dim);line-height:1.7}
.service-link{display:inline-block;margin-top:1.25rem;font-size:.85rem;font-weight:500;color:var(--cyan);opacity:0;transform:translateX(-5px);transition:all .3s}
.service-card:hover .service-link{opacity:1;transform:none}

/* About */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.about-features{display:flex;flex-direction:column;gap:1rem}
.feat-card{background:var(--navy3);border:1px solid var(--border);border-radius:14px;padding:1.25rem 1.5rem;display:flex;align-items:flex-start;gap:1rem;transition:border-color .3s}
.feat-card:hover{border-color:var(--border-glow)}
.feat-icon{width:42px;height:42px;flex-shrink:0;border-radius:10px;background:linear-gradient(135deg,var(--navy4),var(--blue));border:1px solid var(--border-glow);display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.feat-card h4{font-size:.95rem;font-weight:600;color:var(--white);margin-bottom:3px}
.feat-card p{font-size:.82rem;color:var(--white-dim);line-height:1.55}
.udh-checklist{list-style:none;margin:2rem 0}
.udh-checklist li{display:flex;align-items:flex-start;gap:.8rem;font-size:.92rem;color:var(--white-dim);margin-bottom:.85rem;line-height:1.6}
.check-icon{width:20px;height:20px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--blue-mid),var(--cyan));display:flex;align-items:center;justify-content:center;font-size:.6rem;color:var(--navy);font-weight:700;margin-top:2px}

/* Projects */
.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
.project-card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);position:relative;aspect-ratio:16/10;cursor:pointer;transition:all .35s;display:flex;align-items:flex-end}
.project-card:hover{border-color:var(--border-glow);transform:scale(1.01)}
.project-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.project-thumb-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:4rem;transition:transform .5s}
.project-card:hover .project-thumb,.project-card:hover .project-thumb-placeholder{transform:scale(1.05)}
.project-overlay{position:relative;z-index:2;padding:1.5rem;width:100%;background:linear-gradient(transparent,rgba(5,13,31,.95))}
.project-cat{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);margin-bottom:.25rem}
.project-name{font-size:1.05rem;font-weight:600;color:var(--white)}

/* Pricing */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.pricing-card{background:var(--navy2);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem;position:relative;overflow:hidden;transition:all .35s}
.pricing-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border-glow),transparent)}
.pricing-card.featured{border-color:rgba(6,214,245,.5);background:linear-gradient(160deg,var(--navy3),var(--navy2));box-shadow:0 0 50px rgba(6,214,245,.1),0 30px 60px rgba(0,0,0,.3);transform:scale(1.04)}
.pricing-card.featured::before{background:linear-gradient(90deg,transparent,var(--cyan),transparent)}
.popular-tag{position:absolute;top:1.5rem;right:1.5rem;background:linear-gradient(135deg,var(--blue-mid),var(--cyan));color:var(--navy);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .8rem;border-radius:100px}
.plan-name{font-family:var(--font-d);font-size:1.5rem;letter-spacing:.06em;color:var(--white);margin-bottom:.4rem}
.plan-tagline{font-size:.82rem;color:var(--white-dim);margin-bottom:2rem}
.plan-price{font-family:var(--font-d);font-size:4rem;letter-spacing:.03em;color:var(--white);line-height:1}
.plan-price sup{font-size:1.5rem;vertical-align:super;color:var(--cyan)}
.plan-period{font-size:.82rem;color:var(--white-dim);margin-bottom:2rem}
.plan-divider{height:1px;background:var(--border);margin:1.5rem 0}
.plan-features{list-style:none;margin-bottom:2rem}
.plan-features li{display:flex;align-items:center;gap:.6rem;font-size:.875rem;color:var(--white-dim);margin-bottom:.7rem}
.plan-features li::before{content:'→';color:var(--cyan);font-weight:700;flex-shrink:0}
.plan-btn{display:block;text-align:center;padding:.9rem;border-radius:100px;font-size:.9rem;font-weight:600;transition:all .25s;border:1px solid var(--border-glow);color:var(--white);background:var(--white-ghost)}
.plan-btn:hover{background:var(--white-faint);border-color:var(--cyan);color:var(--cyan)}
.pricing-card.featured .plan-btn{background:linear-gradient(135deg,var(--blue-mid),var(--cyan));border-color:transparent;color:var(--navy);font-weight:700}
.pricing-card.featured .plan-btn:hover{box-shadow:0 0 30px rgba(6,214,245,.4);transform:translateY(-1px)}

/* Testimonials */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.testimonial-card{background:var(--navy3);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;transition:border-color .3s;position:relative;overflow:hidden}
.testimonial-card::before{content:'"';position:absolute;top:.5rem;right:1.5rem;font-family:var(--font-d);font-size:6rem;color:var(--blue-mid);opacity:.15;line-height:1;pointer-events:none}
.testimonial-card:hover{border-color:var(--border-glow)}
.testi-stars{color:var(--gold);font-size:.9rem;letter-spacing:2px;margin-bottom:1rem}
.testi-text{font-size:.9rem;line-height:1.75;color:var(--white-dim);margin-bottom:1.5rem;font-style:italic}
.reviewer{display:flex;align-items:center;gap:.75rem}
.reviewer-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--blue-mid),var(--cyan));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:var(--navy);flex-shrink:0}
.reviewer-avatar img{width:40px;height:40px;border-radius:50%;object-fit:cover}
.reviewer-name{font-weight:600;font-size:.9rem;color:var(--white)}
.reviewer-role{font-size:.75rem;color:var(--white-dim)}

/* CTA Band */
.cta-band{background:linear-gradient(135deg,var(--navy3) 0%,var(--blue) 50%,var(--navy3) 100%);padding:6rem 5vw;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(6,214,245,.15),transparent);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
.cta-band h2{font-family:var(--font-d);font-size:clamp(2.2rem,4.5vw,4rem);letter-spacing:.04em;color:var(--white);margin-bottom:1rem;position:relative}
.cta-band p{font-size:1rem;color:var(--white-dim);margin-bottom:2.5rem;position:relative}
.newsletter-form{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;position:relative}
.newsletter-form input{padding:.9rem 1.5rem;border-radius:100px;border:1px solid var(--border-glow);background:rgba(5,13,31,.6);font-size:.95rem;width:320px;max-width:100%;outline:none;color:var(--white);backdrop-filter:blur(10px);font-family:var(--font-b)}
.newsletter-form input::placeholder{color:rgba(240,244,255,.35)}
.newsletter-form input:focus{border-color:var(--cyan)}
.newsletter-form button{background:linear-gradient(135deg,var(--blue-mid),var(--cyan));color:var(--navy);padding:.9rem 2rem;border-radius:100px;border:none;font-size:.95rem;font-weight:700;cursor:pointer;font-family:var(--font-b);transition:all .25s}
.newsletter-form button:hover{box-shadow:0 0 30px rgba(6,214,245,.4);transform:translateY(-1px)}

/* =============================================
   FOOTER
   ============================================= */
#site-footer{background:#030912;border-top:1px solid var(--border);padding:4.5rem 5vw 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3rem;margin-bottom:3.5rem}
.footer-logo{font-family:var(--font-d);font-size:1.6rem;letter-spacing:.06em;color:var(--white);display:flex;align-items:center;gap:10px;margin-bottom:1rem}
.footer-logo .logo-mark{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,var(--blue-mid),var(--cyan));display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}
.footer-logo .logo-accent{color:var(--cyan)}
.footer-logo img{max-height:36px;width:auto}
.footer-desc{font-size:.875rem;color:var(--white-dim);line-height:1.75;margin-bottom:1.5rem}
.footer-socials{display:flex;gap:.6rem}
.social-btn{width:36px;height:36px;border-radius:10px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--white-dim);transition:all .25s}
.social-btn:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(6,214,245,.08)}
.footer-col h4{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--white);margin-bottom:1.25rem}
.footer-col li{margin-bottom:.65rem}
.footer-col a{font-size:.875rem;color:var(--white-dim);transition:color .2s}
.footer-col a:hover{color:var(--cyan)}
.footer-hours{font-size:.875rem;color:var(--white-dim);line-height:1.8}
.footer-bottom{border-top:1px solid var(--border);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:rgba(240,244,255,.25);flex-wrap:wrap;gap:1rem}
.footer-bottom a{color:rgba(240,244,255,.35)}
.footer-bottom a:hover{color:var(--cyan)}

/* WP Core */
.wp-caption{max-width:100%}
.wp-caption-text{font-size:.8rem;color:var(--white-dim);text-align:center;margin-top:.5rem}
.alignleft{float:left;margin:0 1.5rem 1rem 0}
.alignright{float:right;margin:0 0 1rem 1.5rem}
.aligncenter{display:block;margin:1rem auto}
.screen-reader-text{position:absolute;width:1px;height:1px;clip:rect(0,0,0,0);overflow:hidden}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:1.5rem}
.contact-item{display:flex;align-items:flex-start;gap:1rem}
.contact-item-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--navy3),var(--navy4));border:1px solid var(--border-glow);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.contact-item h4{font-size:.9rem;font-weight:600;color:var(--white);margin-bottom:.25rem}
.contact-item p,.contact-item a{font-size:.875rem;color:var(--white-dim)}
.contact-item a:hover{color:var(--cyan)}
.contact-form{background:var(--navy2);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:.82rem;font-weight:500;color:var(--white-dim);margin-bottom:.5rem;letter-spacing:.05em}
.form-group input,.form-group textarea,.form-group select{width:100%;background:var(--navy3);border:1px solid var(--border);border-radius:12px;padding:.85rem 1.25rem;color:var(--white);font-size:.9rem;outline:none;transition:border-color .2s;font-family:var(--font-b)}
.form-group input:focus,.form-group textarea:focus{border-color:var(--cyan)}
.form-group textarea{min-height:140px;resize:vertical}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(240,244,255,.25)}

/* 404 */
.error-404-wrap{min-height:70vh;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;padding:9rem 5vw 5rem}
.error-404-num{font-family:var(--font-d);font-size:10rem;line-height:1;background:linear-gradient(135deg,var(--white),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* =============================================
   RESPONSIVE
   ============================================= */
@media(max-width:1024px){
  .blog-main-layout{grid-template-columns:1fr}
  .blog-sidebar{grid-row:1;display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .pricing-grid{grid-template-columns:repeat(2,1fr)}
  .pricing-card.featured{transform:none}
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .single-post-layout{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .hero-section{grid-template-columns:1fr;padding-top:7rem}
  .hero-visual{order:-1}
  .stats-band{grid-template-columns:repeat(2,1fr)}
  .stat-cell{border-right:none;border-bottom:1px solid var(--border);padding-bottom:1.5rem}
  .stat-cell:nth-child(odd){border-right:1px solid var(--border)}
  .about-grid{grid-template-columns:1fr}
  .projects-grid{grid-template-columns:1fr}
  .services-grid,.pricing-grid,.testimonials-grid{grid-template-columns:1fr}
  .featured-post-card{grid-template-columns:1fr}
  .posts-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .blog-sidebar{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  #primary-navigation{display:none}
  #primary-navigation.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--navy2);border-bottom:1px solid var(--border);padding:1.5rem 5vw;gap:1rem}
  #primary-navigation.open ul{flex-direction:column;gap:1rem}
  .menu-toggle{display:block}
  .float-chip{display:none}
  .hero-blog-stats{gap:1.5rem}
}
