/*
Theme Name: Hesham Elaw — Manga Portfolio
Theme URI: https://example.com/
Author: Hesham Elaw
Author URI: https://example.com/
Description: A clean, black-and-white manga / ink-style one-page portfolio with a custom Projects post type and a matching blog. Built from scratch — no page builder required.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hesham-portfolio
*/

:root{
  --ink:#0c0c0c;
  --paper:#f4f1e9;
  --white:#ffffff;
  --tone:#b9b6ad;
  --line:#0c0c0c;
  --shadow:6px 6px 0 var(--ink);
  --font-display:'Anton',sans-serif;
  --font-label:'Bebas Neue',sans-serif;
  --font-body:'Inter',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  --font-ar:'Cairo',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  overflow-x:hidden;
  background-image:radial-gradient(var(--tone) 0.5px, transparent 0.6px);
  background-size:5px 5px;
}
img{max-width:100%;height:auto}
a{color:inherit}

/* ---------- shared manga pieces ---------- */
.sfx{ font-family:var(--font-display); text-transform:uppercase; line-height:.92; letter-spacing:.5px; font-style:italic; }
.mono{ font-family:var(--font-mono); }
.label{ font-family:var(--font-label); letter-spacing:.18em; }
.halftone{ background-image:radial-gradient(var(--ink) 28%, transparent 30%); background-size:9px 9px; }

.panel{ border:3px solid var(--line); background:var(--white); box-shadow:var(--shadow); position:relative; }

.chapter-tag{
  display:inline-block;font-family:var(--font-label);letter-spacing:.2em;font-size:.85rem;
  border:2px solid var(--ink);padding:3px 12px;background:var(--ink);color:var(--paper);transform:rotate(-2deg);
}

.imgbox{
  border:3px dashed var(--ink);
  background:repeating-linear-gradient(45deg, transparent 0 14px, rgba(12,12,12,.05) 14px 15px), var(--white);
  display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden;
}
.imgbox::before{
  content:"IMG";position:absolute;top:8px;left:8px;font-family:var(--font-label);letter-spacing:.2em;
  font-size:.7rem;background:var(--ink);color:var(--paper);padding:2px 8px;
}
.imgbox .prompt{ font-family:var(--font-mono);font-size:.62rem;line-height:1.5;background:rgba(12,12,12,.88);color:var(--paper);padding:10px 12px; }

/* ---------- nav ---------- */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:60;display:flex;justify-content:space-between;align-items:center;
  padding:14px 22px;background:var(--paper);border-bottom:3px solid var(--ink);
}
.site-nav .brand{ font-family:var(--font-display);font-style:italic;font-size:1.3rem;letter-spacing:.5px;text-decoration:none;}
.site-nav .brand span{ -webkit-text-stroke:1.5px var(--ink); color:transparent;}
.site-nav ul{list-style:none;display:flex;gap:22px;align-items:center;margin:0}
.site-nav a.menu-link{ text-decoration:none;color:var(--ink);font-family:var(--font-label);letter-spacing:.12em;font-size:1rem;transition:.15s}
.site-nav a.menu-link:hover{ background:var(--ink);color:var(--paper);padding:2px 6px}
.site-nav a.menu-link.active{ background:var(--ink);color:var(--paper);padding:2px 6px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer}

/* ---------- HERO ---------- */
.hero{
  min-height:100vh;padding:120px 22px 60px;display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center;
  max-width:1200px;margin:0 auto;position:relative;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:repeating-conic-gradient(from 0deg at 70% 45%, transparent 0deg 2deg, rgba(12,12,12,.06) 2deg 3deg);
  -webkit-mask:radial-gradient(circle at 70% 45%, transparent 28%, #000 60%);mask:radial-gradient(circle at 70% 45%, transparent 28%, #000 60%);
}
.hero-copy{position:relative;z-index:2}
.hero-copy .chapter-tag{margin-bottom:18px}
.hero h1{ font-family:var(--font-display);font-style:italic;text-transform:uppercase;font-size:clamp(3rem,9vw,6.6rem);line-height:.86;letter-spacing:1px; }
.hero h1 .out{ -webkit-text-stroke:2.5px var(--ink);color:transparent;display:block;}
.hero .role{ margin-top:18px;font-family:var(--font-mono);font-size:.95rem;display:inline-block;background:var(--ink);color:var(--paper);padding:8px 14px; }
.hero .blurb{margin-top:22px;max-width:440px;font-size:1.02rem;line-height:1.6}
.hero .cta-row{margin-top:28px;display:flex;gap:14px;flex-wrap:wrap}
.btn{ font-family:var(--font-label);letter-spacing:.14em;font-size:1.05rem;padding:12px 22px;border:3px solid var(--ink);background:var(--ink);color:var(--paper);text-decoration:none;box-shadow:var(--shadow);transition:.12s;cursor:pointer;display:inline-block; }
.btn.ghost{background:var(--white);color:var(--ink)}
.btn:hover{transform:translate(3px,3px);box-shadow:3px 3px 0 var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}
.hero-portrait{position:relative;z-index:2}
.hero-portrait .portrait-img{ width:100%;display:block;border:4px solid var(--ink);box-shadow:10px 10px 0 var(--ink);transform:rotate(2deg);filter:grayscale(1) contrast(1.05);background:var(--white); }
.hero-portrait .name-plate{ position:absolute;bottom:-18px;left:-14px;z-index:3;background:var(--paper);border:3px solid var(--ink);padding:8px 16px;font-family:var(--font-display);font-style:italic;font-size:1.1rem;transform:rotate(-3deg);box-shadow:var(--shadow); }

/* ---------- section frame ---------- */
section.block{max-width:1100px;margin:0 auto;padding:70px 22px}
.sec-head{display:flex;align-items:flex-end;gap:18px;margin-bottom:34px;flex-wrap:wrap}
.sec-head .n{ font-family:var(--font-display);font-style:italic;font-size:clamp(2.4rem,7vw,4.2rem);-webkit-text-stroke:2px var(--ink);color:transparent;line-height:.8; }
.sec-head h2{font-family:var(--font-display);font-style:italic;text-transform:uppercase;font-size:clamp(1.8rem,5vw,3rem);line-height:.9;margin:0}
.sec-head .ch{margin-bottom:auto}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.about-grid .panel{padding:26px}
.about-grid .panel h3{font-family:var(--font-label);letter-spacing:.1em;font-size:1.4rem;margin-bottom:10px}
.about-grid .panel p{font-size:.97rem;line-height:1.62}
.about-grid .panel.dark{background:var(--ink);color:var(--paper)}
.panel-img{ width:100%;display:block;margin-top:16px;border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink);filter:grayscale(1) contrast(1.05);object-fit:cover; }
.about-grid .panel.dark .panel-img{border-color:var(--paper);box-shadow:5px 5px 0 #000}
.panel-img.egypt{aspect-ratio:16/9;object-position:center}

/* SOLUTIONS */
.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.skill{ border:3px solid var(--ink);background:var(--white);padding:18px 18px 16px;box-shadow:var(--shadow);position:relative;transition:.14s; }
.skill:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--ink)}
.skill .num{font-family:var(--font-mono);font-size:.7rem;opacity:.6}
.skill h4{font-family:var(--font-label);letter-spacing:.06em;font-size:1.5rem;margin:4px 0 8px}
.skill p{font-size:.86rem;line-height:1.55}
.skill .tag{position:absolute;top:14px;right:14px;width:30px;height:30px}
.skill .tag.halftone{border:2px solid var(--ink);border-radius:50%}

/* PROJECTS */
.proj{
  display:grid;grid-template-columns:1fr 1fr;gap:0;border:3px solid var(--ink);box-shadow:var(--shadow);background:var(--white);margin-bottom:36px;overflow:hidden;position:relative;
}
.proj:nth-child(even) .proj-img{order:2;border-left:3px solid var(--ink);border-right:0}
.proj:nth-child(even) .proj-body{order:1}
.proj-img{border-right:3px solid var(--ink);min-height:280px}
.proj-img .imgbox{height:100%;border:0;box-shadow:none}
.proj-img .proj-photo{width:100%;height:100%;display:block;object-fit:cover;filter:grayscale(1) contrast(1.04)}
.proj-body{padding:28px 30px;display:flex;flex-direction:column;justify-content:center}
.proj-body .ep{font-family:var(--font-mono);font-size:.72rem;color:#555;margin-bottom:8px}
.proj-body h3{font-family:var(--font-display);font-style:italic;text-transform:uppercase;font-size:clamp(1.5rem,3.5vw,2.3rem);line-height:.92;margin:0}
.proj-body h3 a{text-decoration:none}
.proj-body .role{display:inline-block;margin-top:10px;font-family:var(--font-label);letter-spacing:.12em;background:var(--ink);color:var(--paper);padding:3px 12px;font-size:.95rem}
.proj-body p{margin-top:14px;font-size:.95rem;line-height:1.6}
.proj-body .stack{margin-top:16px;display:flex;gap:8px;flex-wrap:wrap}
.proj-body .stack span{font-family:var(--font-mono);font-size:.68rem;border:1.5px solid var(--ink);padding:3px 8px}
.proj-body .link{margin-top:18px}
.proj-body .link a{font-family:var(--font-label);letter-spacing:.1em;text-decoration:none;color:var(--ink);border-bottom:3px solid var(--ink);font-size:1.1rem}
.proj-body .link a:hover{background:var(--ink);color:var(--paper)}
.wip{position:absolute;top:14px;right:14px;background:var(--ink);color:var(--paper);font-family:var(--font-label);letter-spacing:.16em;padding:3px 12px;transform:rotate(4deg);font-size:.85rem;z-index:4}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.post-card{ border:3px solid var(--ink);background:var(--white);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;transition:.14s; }
.post-card:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--ink)}
.post-card .thumb{aspect-ratio:16/10;border-bottom:3px solid var(--ink);overflow:hidden;background:var(--ink)}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.04)}
.post-card .thumb.placeholder{display:flex;align-items:center;justify-content:center}
.post-card .thumb.placeholder span{font-family:var(--font-display);font-style:italic;color:var(--paper);font-size:2rem;opacity:.5}
.post-card .pc-body{padding:20px 22px;display:flex;flex-direction:column;flex:1}
.post-card .pc-date{font-family:var(--font-mono);font-size:.68rem;color:#555;margin-bottom:8px}
.post-card h3{font-family:var(--font-display);font-style:italic;text-transform:uppercase;font-size:1.35rem;line-height:.98;margin:0}
.post-card h3 a{text-decoration:none}
.post-card p{margin-top:12px;font-size:.9rem;line-height:1.55;flex:1}
.post-card .pc-more{margin-top:16px;font-family:var(--font-label);letter-spacing:.1em;text-decoration:none;border-bottom:3px solid var(--ink);align-self:flex-start;font-size:1rem}
.post-card .pc-more:hover{background:var(--ink);color:var(--paper)}
.blog-foot{margin-top:34px;text-align:center}

/* SINGLE / ARCHIVE */
.single-wrap{max-width:760px;margin:0 auto;padding:120px 22px 70px}
.single-wrap .chapter-tag{margin-bottom:18px}
.single-wrap h1.entry-title{font-family:var(--font-display);font-style:italic;text-transform:uppercase;font-size:clamp(2rem,6vw,3.4rem);line-height:.92;margin:10px 0 14px}
.single-wrap .meta{font-family:var(--font-mono);font-size:.74rem;color:#555;margin-bottom:24px}
.single-wrap .featured{border:3px solid var(--ink);box-shadow:var(--shadow);margin-bottom:30px}
.single-wrap .featured img{display:block;width:100%;filter:grayscale(1) contrast(1.04)}
.entry-content{font-size:1.04rem;line-height:1.75}
.entry-content p{margin:0 0 1.1em}
.entry-content h2{font-family:var(--font-label);letter-spacing:.06em;font-size:1.8rem;margin:1.6em 0 .5em}
.entry-content h3{font-family:var(--font-label);letter-spacing:.06em;font-size:1.4rem;margin:1.4em 0 .4em}
.entry-content a{border-bottom:2px solid var(--ink)}
.entry-content blockquote{border-left:4px solid var(--ink);padding-left:18px;margin:1.2em 0;font-style:italic;background:var(--white)}
.entry-content img{border:3px solid var(--ink);box-shadow:var(--shadow);margin:1em 0}
.entry-content ul,.entry-content ol{margin:0 0 1.1em 1.3em}
.entry-content code{font-family:var(--font-mono);background:var(--ink);color:var(--paper);padding:1px 6px;font-size:.85em}
.entry-content pre{background:var(--ink);color:var(--paper);padding:18px;overflow:auto;border:3px solid var(--ink);box-shadow:var(--shadow);margin:1.2em 0}
.entry-content pre code{background:none;padding:0}
.post-nav{display:flex;justify-content:space-between;gap:14px;margin-top:40px;border-top:3px solid var(--ink);padding-top:22px;font-family:var(--font-label);letter-spacing:.08em}
.post-nav a{text-decoration:none}
.post-nav a:hover{background:var(--ink);color:var(--paper);padding:2px 6px}
.back-home{display:inline-block;margin-bottom:18px;font-family:var(--font-label);letter-spacing:.1em;text-decoration:none;border-bottom:3px solid var(--ink)}

.archive-head{max-width:1100px;margin:0 auto;padding:120px 22px 0}
.comments-area{margin-top:40px;border-top:3px solid var(--ink);padding-top:24px}

/* COMMENT FORM */
.comment-respond{margin-top:30px;border:3px solid var(--ink);background:var(--white);box-shadow:var(--shadow);padding:26px 28px}
.comment-reply-title{font-family:var(--font-display);font-style:italic;text-transform:uppercase;font-size:1.7rem;line-height:1;margin:0 0 14px}
.comment-reply-title small{display:block;margin-top:8px;font-family:var(--font-mono);font-size:.72rem;font-style:normal}
.comment-reply-title small a{border-bottom:2px solid var(--ink);text-decoration:none}
.comment-form .comment-notes{font-size:.85rem;color:#555;margin:0 0 18px}
.comment-form .logged-in-as{font-size:.85rem;color:#555;margin:0 0 16px}
.comment-form p{margin:0 0 16px}
.comment-form label{display:block;font-family:var(--font-label);letter-spacing:.08em;font-size:1.05rem;margin-bottom:5px}
.comment-form input[type=text],
.comment-form input[type=email],
.comment-form input[type=url],
.comment-form textarea{
  width:100%;font-family:var(--font-body);font-size:.95rem;padding:11px 13px;background:var(--paper);
  border:3px solid var(--ink);color:var(--ink);outline:none;transition:box-shadow .12s;
}
.comment-form textarea{min-height:130px;resize:vertical}
.comment-form input:focus,.comment-form textarea:focus{box-shadow:4px 4px 0 var(--ink)}
.comment-form .required{color:var(--ink);font-weight:700}
.comment-form-hp-captcha label{display:inline-block;font-family:var(--font-mono);letter-spacing:0;font-size:.85rem;margin-bottom:6px}
.comment-form-hp-captcha input{width:110px}
.comment-form-cookies-consent{display:flex;align-items:flex-start;gap:8px}
.comment-form-cookies-consent input{width:auto;margin-top:3px}
.comment-form-cookies-consent label{font-family:var(--font-body);letter-spacing:0;font-size:.85rem;color:#555;text-transform:none}
.form-submit{margin-bottom:0}
.form-submit .submit{
  font-family:var(--font-label);letter-spacing:.14em;font-size:1.05rem;padding:12px 26px;
  border:3px solid var(--ink);background:var(--ink);color:var(--paper);box-shadow:var(--shadow);cursor:pointer;transition:.12s;
}
.form-submit .submit:hover{transform:translate(3px,3px);box-shadow:3px 3px 0 var(--ink)}
/* honeypot — kept off-screen, never shown to humans */
.hp-hp-field{position:absolute !important;left:-9999px !important;top:auto;width:1px;height:1px;overflow:hidden}

/* COMMENT LIST */
.comments-area .comment-list{list-style:none;margin:0 0 30px;padding:0}
.comments-area .comment-list li.comment{list-style:none}
.comments-area .comment-list .comment-body{border:3px solid var(--ink);background:var(--white);box-shadow:var(--shadow);padding:18px 20px;margin:0 0 18px}
.comments-area .comment-list .children{list-style:none;margin:0 0 0 24px;padding:0}
.comments-area .comment-author{font-family:var(--font-label);letter-spacing:.06em;font-size:1.1rem;display:flex;align-items:center;gap:10px}
.comments-area .comment-author .avatar{border:2px solid var(--ink);display:block}
.comments-area .comment-author .says{display:none}
.comments-area .comment-metadata{font-family:var(--font-mono);font-size:.7rem;color:#666;margin:6px 0 10px}
.comments-area .comment-metadata a{text-decoration:none}
.comments-area .comment-content p{font-size:.95rem;line-height:1.6;margin:0 0 .8em}
.comments-area .reply a{font-family:var(--font-label);letter-spacing:.08em;text-decoration:none;border-bottom:2px solid var(--ink);font-size:.92rem}
.comments-area .reply a:hover{background:var(--ink);color:var(--paper)}
.comments-area .comment-respond{margin-top:18px}
.comments-area .no-comments{font-family:var(--font-mono);font-size:.85rem;color:#555}

/* CONTACT */
.contact{background:var(--ink);color:var(--paper);border-top:4px solid var(--ink);position:relative;overflow:hidden}
.contact::before{ content:"";position:absolute;inset:0;opacity:.12;background-image:radial-gradient(var(--paper) 30%, transparent 32%);background-size:14px 14px; }
.contact-inner{max-width:900px;margin:0 auto;padding:90px 22px;position:relative;z-index:2;text-align:center}
.contact .tbc{font-family:var(--font-display);font-style:italic;font-size:clamp(2.6rem,8vw,5rem);line-height:.9;text-transform:uppercase}
.contact .tbc .out{-webkit-text-stroke:2px var(--paper);color:transparent}
.contact p{margin:20px auto 0;max-width:520px;line-height:1.6;opacity:.92}
.contact .links{margin-top:34px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.contact .links a{ font-family:var(--font-label);letter-spacing:.12em;font-size:1.1rem;text-decoration:none;color:var(--ink);background:var(--paper);padding:12px 22px;border:3px solid var(--paper);transition:.12s }
.contact .links a:hover{background:transparent;color:var(--paper)}
.site-footer{background:var(--ink);color:var(--paper);text-align:center;padding:22px;font-family:var(--font-mono);font-size:.72rem;border-top:1px solid #333}
.site-footer .footer-social{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-bottom:14px}
.site-footer .footer-social a{font-family:var(--font-label);letter-spacing:.12em;font-size:.95rem;text-decoration:none;color:var(--paper);opacity:.85;transition:.12s}
.site-footer .footer-social a:hover{opacity:1;border-bottom:2px solid var(--paper)}
.site-footer .footer-credit{opacity:.8}

/* reveal animation */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* WhatsApp floating button */
.wa-float{
  position:fixed;bottom:22px;right:22px;z-index:80;
  width:56px;height:56px;display:flex;align-items:center;justify-content:center;
  background:var(--ink);border:3px solid var(--ink);box-shadow:var(--shadow);
  transition:transform .14s, box-shadow .14s;
}
.wa-float svg{width:30px;height:30px;fill:var(--paper);display:block}
.wa-float:hover{transform:translate(3px,3px);box-shadow:3px 3px 0 var(--ink)}
body.rtl-home .wa-float{right:auto;left:22px}
@media(max-width:560px){
  .wa-float{width:50px;height:50px;bottom:16px;right:16px}
  body.rtl-home .wa-float{left:16px;right:auto}
}
@media(prefers-reduced-motion:reduce){ .wa-float{transition:none} }

/* ---------- responsive ---------- */
@media(max-width:860px){
  .site-nav ul{position:fixed;inset:60px 0 auto 0;flex-direction:column;background:var(--paper);border-bottom:3px solid var(--ink);padding:16px 22px;display:none}
  .site-nav ul.open{display:flex}
  .nav-toggle{display:block;font-family:var(--font-display);font-style:italic;font-size:1.4rem}
  .hero{grid-template-columns:1fr;gap:50px;padding-top:100px}
  .hero-portrait{max-width:360px;margin:0 auto;width:100%}
  .about-grid{grid-template-columns:1fr}
  .skills-grid{grid-template-columns:1fr 1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
  .proj,.proj:nth-child(even){grid-template-columns:1fr}
  .proj-img,.proj:nth-child(even) .proj-img{border:0;border-bottom:3px solid var(--ink);order:1}
  .proj-body,.proj:nth-child(even) .proj-body{order:2}
}
@media(max-width:480px){
  .skills-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
