/*
Theme Name: K Man Theme
Theme URI: https://kawsarali.com
Author: Kawsar Ali
Description: Portfolio theme for WordPress professionals.
Version: 2.7.0
License: GNU General Public License v2 or later
Text Domain: kman-theme
*/

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;1,9..40,300&family=DM+Mono:wght@400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#ffffff;
  --bg-soft:#f7f7f5;
  --text:#111111;
  --muted:#5a5a58;
  --hint:#9a9a98;
  --border:rgba(0,0,0,.09);
  --border-md:rgba(0,0,0,.16);
  --accent:#534AB7;
  --accent-light:#EEEDFE;
  --accent-dark:#3C3489;
  --card1:#f0effd;
  --card2:#edf7f3;
  --card3:#fdf6ec;
  --r-sm:6px;
  --r-md:10px;
  --r-lg:14px;
  --r-pill:100px;
  --font:'DM Sans',system-ui,sans-serif;
  --mono:'DM Mono',monospace;
  --max-w:950px;
  --hero-align:left;
  --hero-padding:0px;
  --role-size:28px;
  --hero-inner-max-w:760px;
}

html{font-size:16px;-webkit-font-smoothing:antialiased}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.7;min-height:100vh}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
p{margin-bottom:1em}
p:last-child{margin-bottom:0}

/* ── Shell ── */
.site-shell{max-width:var(--max-w);margin:0 auto;border-left:0.5px solid var(--border);border-right:0.5px solid var(--border);min-height:100vh;display:flex;flex-direction:column}

/* ── Top nav ── */
.site-header{border-bottom:0.5px solid var(--border);padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:56px;position:sticky;top:0;background:var(--bg);z-index:100;flex-shrink:0}
.site-name-wrap{display:flex;flex-direction:column;justify-content:center}
.site-name-text{font-size:13px;font-weight:500;color:var(--text);letter-spacing:.48em;text-transform:uppercase;line-height:1;white-space:nowrap}
.site-name-line{height:2px;background:var(--accent);border-radius:2px;width:0;margin-top:5px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.site-name-line.drawn{width:100%}
.site-nav{display:flex;gap:24px;list-style:none}
.site-nav a{font-size:12px;color:var(--muted);transition:color .15s}
.site-nav a:hover,.site-nav .current-menu-item a,.site-nav .current_page_item a{color:var(--text)}
.site-nav .current-menu-item a,.site-nav .current_page_item a{font-weight:500;color:var(--text)}

/* ── Hamburger ── */
.hamburger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:4px;z-index:102}
.hamburger span{display:block;width:20px;height:1.5px;background:var(--text);border-radius:2px;transition:transform .25s,opacity .2s}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ── Drawer ── */
.nav-drawer{position:fixed;top:0;left:0;width:260px;height:100vh;background:var(--bg);border-right:0.5px solid var(--border);z-index:300;padding:1.5rem 1.5rem 2rem;transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);overflow-y:auto}
.nav-drawer.open{transform:translateX(0)}
.drawer-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.28);z-index:299}
.drawer-overlay.open{display:block}
.drawer-close{background:none;border:none;cursor:pointer;font-size:20px;color:var(--muted);position:absolute;top:1rem;right:1rem;padding:4px 8px;line-height:1}
.drawer-site-name{font-size:13px;font-weight:500;color:var(--text);letter-spacing:.3em;text-transform:uppercase;display:block;margin-bottom:6px}
.drawer-name-line{height:2px;background:var(--accent);border-radius:2px;width:100%;display:block;margin-bottom:2rem}
.drawer-nav{list-style:none;padding:0;margin:0}
.drawer-nav li{border-bottom:0.5px solid var(--border);list-style:none}
.drawer-nav li::marker{display:none}
.drawer-nav a{font-size:15px;color:var(--text);display:block;padding:10px 0}
.drawer-nav a:hover{color:var(--accent)}

/* ── Main ── */
.site-main{flex:1;padding:40px 32px 64px}

/* ══════════════════════════════
   HERO — unified flex for both alignments
══════════════════════════════ */
.hero{
  padding-bottom:36px;
  border-bottom:0.5px solid var(--border);
  margin-bottom:36px;
}

/* hero-inner is always flex row: text left, avatar right */
.hero-inner{
  display:flex;
  flex-direction:row;
  align-items:flex-start;
  gap:32px;
  width:100%;
}

/* LEFT: full width, avatar on the right */
.hero[data-align="left"] .hero-inner{
  justify-content:flex-start;
  padding-left:var(--hero-padding);
  padding-right:var(--hero-padding);
}

/* CENTER: constrained width, centered, text left avatar right */
.hero[data-align="center"]{
  display:flex;
  justify-content:center;
}
.hero[data-align="center"] .hero-inner{
  max-width:var(--hero-inner-max-w);
  justify-content:flex-start;
  padding-left:var(--hero-padding);
  padding-right:var(--hero-padding);
}

.hero-text{flex:1;min-width:0}
.hero-avatar{flex-shrink:0;margin-top:4px;width:110px;height:110px;margin-top:50px}

.hero-avatar{width:84px;height:84px;border-radius:50%;overflow:hidden;border:0.5px solid var(--border)}
.hero-avatar img{width:100%;height:100%;object-fit:cover}
.hero-avatar-placeholder{width:100%;height:100%;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:400;color:var(--hint);letter-spacing:.1em}

.hero-eyebrow{font-size:12px;color:var(--hint);margin-bottom:10px;letter-spacing:.02em}
.hero-heading{font-size:var(--role-size);font-weight:400;line-height:1.25;color:var(--text);letter-spacing:-.02em;margin-bottom:14px}
.hero-body{font-size:13px;color:var(--muted);max-width:500px;line-height:1.75;margin-bottom:22px}
.hero-roles .role{display:none;color:var(--accent)}
.hero-roles .role.active{display:inline}

/* ── Button ── */
.btn-primary{display:inline-flex;align-items:center;background:var(--accent);color:#fff;border:none;border-radius:var(--r-pill);padding:10px 24px;font-size:13px;font-family:var(--font);font-weight:500;cursor:pointer;transition:opacity .15s;text-decoration:none}
.btn-primary:hover{opacity:.85;color:#fff}

/* ── Section label ── */
.section-label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--hint);margin-bottom:16px}
.section-divider{border:none;border-top:0.5px solid var(--border);margin:36px 0}

/* ══════════════════════════════
   PROJECT CARDS
══════════════════════════════ */
.project-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:.5rem}
.project-card{border:0.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--bg);transition:border-color .2s,transform .2s;display:flex;flex-direction:column;padding:20px}
.project-card:hover{border-color:var(--border-md);transform:translateY(-2px)}
.project-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.project-icon{width:34px;height:34px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.project-icon svg{width:17px;height:17px}
.icon-1{background:var(--card1)}
.icon-1 svg{color:var(--accent)}
.icon-2{background:var(--card2)}
.icon-2 svg{color:#1D9E75}
.icon-3{background:var(--card3)}
.icon-3 svg{color:#c07a18}
.industry-label{font-size:11px;color:var(--hint);letter-spacing:.02em}
.project-title{font-size:15px;font-weight:500;color:var(--text);margin-bottom:10px;line-height:1.3}
.project-desc{font-size:12px;color:var(--muted);line-height:1.65;flex:1}
.project-link{display:inline-block;margin-top:12px;font-size:11px;color:var(--accent)}
.client-note{font-size:11px;color:var(--hint);font-style:italic;margin-top:8px}

/* ══════════════════════════════
   STACK - slash fixed
══════════════════════════════ */
.stack-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.stack-cat-title{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--hint);margin-bottom:10px}
.stack-tags-pills{display:flex;flex-wrap:wrap;gap:4px}
.tag{display:inline-block;font-size:11px;padding:3px 9px;border-radius:var(--r-pill);background:var(--bg-soft);color:var(--muted);border:0.5px solid var(--border)}
.tag-primary{background:var(--accent-light);color:var(--accent-dark);border-color:transparent}

/* Slash - all items inline with / separator */
.stack-tags-slash{font-size:12px;color:var(--muted);line-height:1.9}
.stack-slash-item{display:inline}
.stack-slash-item+.stack-slash-item::before{content:' / ';color:var(--hint)}
.stack-slash-first{color:var(--accent);font-weight:500}

/* ── About ── */
.page-title{font-size:clamp(22px,3vw,30px);font-weight:400;letter-spacing:-.02em;margin-bottom:2rem;line-height:1.2}
.about-body{font-size:14px;color:var(--muted);line-height:1.85;max-width:680px}
.about-body p{margin-bottom:1.25em}
.page-with-sidebar{display:grid;grid-template-columns:1fr 180px;gap:3rem;align-items:start}
.sidebar-meta-item{padding:10px 0;border-bottom:0.5px solid var(--border);color:var(--muted);font-size:13px}
.sidebar-meta-item strong{color:var(--text);font-weight:500;display:block;font-size:10px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}

/* ── Blog ── */
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.post-card{border:0.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--bg);transition:border-color .2s;display:flex;flex-direction:column}
.post-card:hover{border-color:var(--border-md)}
.post-thumb-link{display:block;flex-shrink:0}
.post-thumb{aspect-ratio:16/9;overflow:hidden;background:var(--bg-soft)}
.post-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.post-thumb-placeholder{aspect-ratio:16/9;background:var(--bg-soft)}
.post-card:hover .post-thumb img{transform:scale(1.03)}
.post-body{padding:14px;flex:1;display:flex;flex-direction:column}
.post-date{font-size:11px;color:var(--accent);margin-bottom:6px}
.post-title{font-size:14px;font-weight:500;color:var(--text);line-height:1.4;margin-bottom:6px}
.post-title a{color:var(--text)}
.post-title a:hover{color:var(--accent)}
.post-excerpt{font-size:12px;color:var(--muted);line-height:1.6}

/* ── Single post ── */
.post-single{max-width:680px;margin:0 auto}
.post-single-meta{font-size:12px;color:var(--hint);margin-bottom:2rem;text-align:center}
.post-single-title{font-size:clamp(22px,3vw,32px);font-weight:500;letter-spacing:-.02em;margin-bottom:2rem;line-height:1.2;text-align:center}
.post-featured-img{margin:0 -32px 2.5rem;overflow:hidden;max-height:420px}
.post-featured-img img{width:100%;height:100%;object-fit:cover}
.post-content{font-size:16px;color:var(--muted);line-height:1.9}
.post-content h2{font-size:20px;font-weight:500;color:var(--text);margin:2rem 0 .75rem}
.post-content h3{font-size:16px;font-weight:500;color:var(--text);margin:1.5rem 0 .4rem}
.post-content p{margin-bottom:1.4em}
.post-content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.post-content code{font-size:13px;background:var(--bg-soft);padding:2px 6px;border-radius:4px;border:0.5px solid var(--border)}
.post-content pre{background:var(--bg-soft);border:0.5px solid var(--border);border-radius:var(--r-md);padding:1.25rem;overflow-x:auto;margin:1.5rem 0}
.post-content pre code{background:none;border:none;padding:0}
.post-content ul,.post-content ol{padding-left:1.5rem;margin:1rem 0 1.4rem}
.post-content li{margin-bottom:.5rem}
.post-content blockquote{border-left:3px solid var(--accent);padding-left:1.25rem;color:var(--hint);font-style:italic;margin:2rem 0;font-size:17px;line-height:1.7}
.post-content img{border-radius:var(--r-md);margin:1.5rem 0}
.post-back{margin-top:3rem;padding-top:1.5rem;border-top:0.5px solid var(--border);text-align:center}
.post-back a{font-size:13px;color:var(--accent)}

/* ── Contact ── */
.contact-wrap{max-width:480px}
.contact-links{display:flex;flex-direction:column}
.contact-link{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--muted);padding:12px 0;border-bottom:0.5px solid var(--border);transition:color .15s}
.contact-link:hover{color:var(--text)}

/* ── Footer ── */
.site-footer{border-top:0.5px solid var(--border);padding:1.25rem 32px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.footer-copy{font-size:12px;color:var(--hint)}
.footer-links{display:flex;gap:16px;flex-wrap:wrap}
.footer-links a{font-size:12px;color:var(--muted);transition:color .15s}
.footer-links a:hover{color:var(--text)}

/* ── Pagination ── */
.pagination{display:flex;gap:8px;margin-top:2rem;flex-wrap:wrap}
.pagination a,.pagination span{font-size:12px;padding:5px 10px;border-radius:var(--r-sm);border:0.5px solid var(--border);color:var(--muted)}
.pagination .current{background:var(--accent);color:#fff;border-color:var(--accent)}
.pagination a:hover{border-color:var(--border-md);color:var(--text)}

/* ── WP helpers ── */
.alignleft{float:left;margin:0 1.5rem 1rem 0}
.alignright{float:right;margin:0 0 1rem 1.5rem}
.aligncenter{margin:0 auto 1rem}
.wp-caption-text{font-size:12px;color:var(--hint);margin-top:4px}

/* ══════════════════
   RESPONSIVE
══════════════════ */
@media(max-width:768px){
  .site-header{padding:0 16px}
  .site-nav{display:none!important}
  .hamburger{display:flex!important}
  .site-main{padding:20px 0 48px}

  /* Hero mobile */
  /* Hero mobile - avatar above text */
  .hero{padding:0 16px 24px;margin-bottom:24px}
  .hero-inner{flex-direction:column-reverse;gap:12px}
  .hero[data-align="center"]{display:block}
  .hero[data-align="center"] .hero-inner{padding-left:0;padding-right:0}
  .hero-avatar{width:60px;height:60px;margin-top:0}

  .section-label{padding:0 16px}
  .project-grid{grid-template-columns:1fr;padding:0 16px}
  .stack-grid{grid-template-columns:1fr 1fr;padding:0 16px}  .section-divider{margin:24px 16px}
  .page-title{padding:0 16px}
  .about-body{padding:0 16px}
  .page-with-sidebar{grid-template-columns:1fr;padding:0 16px}
  .post-grid{grid-template-columns:1fr 1fr;padding:0 16px}
  .client-note{padding:0 16px}
  .post-single{padding:0 16px}
  .post-featured-img{margin:0 0 2rem}
  .post-single-title,.post-single-meta{text-align:left}
  .contact-wrap{padding:0 16px}
  .site-footer{padding:1rem 16px;flex-direction:column;align-items:flex-start;gap:8px}
  .site-shell{border-left:none;border-right:none}
  .pagination{padding:0 16px}
}
@media(max-width:480px){
  .project-grid,.post-grid,.stack-grid{grid-template-columns:1fr}
}
