/*
Theme Name: Zeshan Haider
Theme URI: https://zeshanhaider.dev
Author: Zeshan Haider
Author URI: https://zeshanhaider.dev
Description: Custom portfolio and WordPress security services theme for Zeshan Haider. Dark/light, fully responsive, with animated hero scanner and brand-colored contact channels. Built to pair with a client-portal/invoicing plugin.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: zeshan
Tags: portfolio, one-page, responsive, custom-colors, translation-ready
*/

  :root{
    --bg:#080b0e;--bg-2:#0d1216;--surface:#111820;--line:#1e2a33;
    --ink:#e9f1f4;--muted:#8fa3ac;--faint:#5e727b;
    --teal:#2dd4bf;--teal-soft:#5eead4;--cyan:#22a5c9;--lime:#a3e635;
    --on-teal:#04120f;--grid-line:var(--line);--header-bg:rgba(8,11,14,.82);
    --shadow:rgba(0,0,0,.72);--r:14px;--maxw:1180px;
  }
  html[data-theme="light"]{
    --bg:#f4f7f8;--bg-2:#e9eff1;--surface:#ffffff;--line:#dce5e8;
    --ink:#0f1a1f;--muted:#51636b;--faint:#87979e;
    --teal:#0d9488;--teal-soft:#14b8a6;--cyan:#0e7490;--lime:#4d7c0f;
    --on-teal:#ffffff;--grid-line:#dce5e8;--header-bg:rgba(244,247,248,.85);--shadow:rgba(60,80,88,.2);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth;transition:background .3s}
  body{background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .3s,color .3s}
  a{color:inherit;text-decoration:none}
  ::selection{background:var(--teal);color:var(--on-teal)}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
  .mono{font-family:'JetBrains Mono',monospace}
  h1,h2,h3{font-family:'Sora',sans-serif;font-weight:700;line-height:1.1;letter-spacing:-.02em}
  .eyebrow{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);display:inline-flex;align-items:center;gap:10px}
  .eyebrow::before{content:"";width:24px;height:1px;background:var(--teal)}
  .eyebrow .enum{font-size:10.5px;color:var(--on-teal);background:var(--teal);border-radius:4px;padding:2px 6px;letter-spacing:.05em;font-weight:600}
  header{position:fixed;top:0;left:0;right:0;z-index:50;transition:.3s}
  header.scrolled{background:var(--header-bg);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
  nav{display:flex;align-items:center;justify-content:space-between;height:74px}
  .logo{font-family:'Sora',sans-serif;font-weight:700;font-size:19px;letter-spacing:-.02em;display:flex;align-items:center;gap:9px}
  .logo .mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--teal),var(--cyan));display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .logo .mark svg{width:17px;height:17px;fill:var(--on-teal)}
  .logo span{color:var(--teal)}
  .nav-links{display:flex;gap:32px;align-items:center}
  .nav-links a{font-size:14.5px;color:var(--muted);transition:.2s}
  .nav-links a:hover{color:var(--ink)}
  .nav-cta{background:var(--teal);color:var(--on-teal)!important;padding:10px 20px;border-radius:8px;font-weight:600;font-size:14px;transition:.2s}
  .nav-cta:hover{background:var(--teal-soft);transform:translateY(-1px)}
  .nav-actions{display:flex;align-items:center;gap:10px}
  .theme-toggle{width:40px;height:40px;border-radius:9px;background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);transition:.2s}
  .theme-toggle:hover{color:var(--teal);border-color:var(--teal)}
  .theme-toggle .icon-moon{display:none}
  html[data-theme="light"] .theme-toggle .icon-sun{display:none}
  html[data-theme="light"] .theme-toggle .icon-moon{display:block}
  .burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0}
  .burger span{width:24px;height:2px;background:var(--ink);transition:.3s}
  .hero{position:relative;padding:150px 0 90px;overflow:hidden}
  .grid-bg{position:absolute;inset:0;z-index:0;background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:54px 54px;opacity:.4;-webkit-mask-image:radial-gradient(ellipse 80% 60% at 72% 32%,#000,transparent 75%);mask-image:radial-gradient(ellipse 80% 60% at 72% 32%,#000,transparent 75%)}
  .glow{position:absolute;top:-12%;right:-6%;width:640px;height:640px;border-radius:50%;background:radial-gradient(circle,rgba(45,212,191,.14),transparent 65%);z-index:0;pointer-events:none}
  .hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:52px;align-items:center}
  .status{display:inline-flex;align-items:center;gap:9px;font-size:13px;color:var(--muted);border:1px solid var(--line);background:var(--surface);padding:7px 15px;border-radius:100px;margin-bottom:26px}
  .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 0 rgba(45,212,191,.5);animation:pulse 2s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(45,212,191,.5)}70%{box-shadow:0 0 0 9px rgba(45,212,191,0)}100%{box-shadow:0 0 0 0 rgba(45,212,191,0)}}
  .hero h1{font-size:clamp(38px,5.6vw,64px);margin-bottom:22px;font-weight:800}
  .hero h1 em{font-style:normal;background:linear-gradient(120deg,var(--teal),var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
  .hero p.lead{font-size:18px;color:var(--muted);max-width:490px;margin-bottom:30px}
  .hero-tags{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:32px}
  .htag{font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--muted);background:var(--bg-2);border:1px solid var(--line);padding:7px 13px;border-radius:7px;display:inline-flex;align-items:center;gap:7px}
  .htag svg{width:13px;height:13px;stroke:var(--teal)}
  .hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:44px}
  .btn{padding:14px 26px;border-radius:9px;font-weight:600;font-size:15px;transition:.2s;display:inline-flex;align-items:center;gap:9px;cursor:pointer;border:0}
  .btn-primary{background:var(--teal);color:var(--on-teal)}
  .btn-primary:hover{background:var(--teal-soft);transform:translateY(-2px)}
  .btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
  .btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
  .hero-stats{display:flex;gap:36px;border-top:1px solid var(--line);padding-top:24px}
  .hero-stats .num{font-family:'Sora',sans-serif;font-size:28px;font-weight:700;color:var(--ink)}
  .hero-stats .lbl{font-size:13px;color:var(--faint)}
  .scanner{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:0 30px 80px -30px var(--shadow);overflow:hidden}
  .scanner::after{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,transparent,var(--teal),transparent);animation:scan 3.4s ease-in-out infinite;opacity:.9}
  @keyframes scan{0%{transform:translateY(0)}50%{transform:translateY(340px)}100%{transform:translateY(0)}}
  .scan-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
  .scan-head .site{font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:8px}
  .scan-head .site .lock{width:14px;height:14px;stroke:var(--teal)}
  .scan-badge{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--teal);background:rgba(45,212,191,.1);border:1px solid rgba(45,212,191,.3);padding:4px 10px;border-radius:6px}
  /* signature: terminal line under hero */
  .terminal{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--muted);background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:11px 15px;margin-bottom:32px;display:inline-flex;align-items:center;gap:9px;min-width:320px;max-width:100%;overflow:hidden}
  .terminal .prompt{color:var(--teal);flex-shrink:0}
  .terminal .type{white-space:nowrap;overflow:hidden}
  .terminal .caret{display:inline-block;width:8px;height:15px;background:var(--teal);margin-left:1px;animation:blink 1.1s step-end infinite;vertical-align:-2px}
  @keyframes blink{50%{opacity:0}}
  /* signature: corner brackets on scanner (security scope motif) */
  .scanner .bracket{position:absolute;width:16px;height:16px;border-color:var(--teal);opacity:.55;z-index:3;pointer-events:none}
  .scanner .bracket.tl{top:12px;left:12px;border-top:2px solid;border-left:2px solid;border-top-left-radius:4px}
  .scanner .bracket.tr{top:12px;right:12px;border-top:2px solid;border-right:2px solid;border-top-right-radius:4px}
  .scanner .bracket.bl{bottom:12px;left:12px;border-bottom:2px solid;border-left:2px solid;border-bottom-left-radius:4px}
  .scanner .bracket.br{bottom:12px;right:12px;border-bottom:2px solid;border-right:2px solid;border-bottom-right-radius:4px}
  .scan-foot .big .cnt{font-variant-numeric:tabular-nums}
  .scan-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}
  .scan-row:last-child{border-bottom:0}
  .scan-check{width:26px;height:26px;border-radius:7px;background:rgba(45,212,191,.12);display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .scan-check svg{width:15px;height:15px;stroke:var(--teal)}
  .scan-row .label{font-size:14px;color:var(--ink);flex:1}
  .scan-row .val{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--faint)}
  .scan-foot{margin-top:18px;display:flex;align-items:center;gap:11px;background:var(--bg-2);border:1px solid var(--line);border-radius:11px;padding:14px 16px}
  .scan-foot .big{font-family:'Sora',sans-serif;font-weight:700;font-size:22px;color:var(--teal)}
  .scan-foot .sub{font-size:12.5px;color:var(--muted)}
  .marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2);overflow:hidden;padding:18px 0}
  .marquee-track{display:flex;gap:52px;white-space:nowrap;animation:scroll 26s linear infinite;width:max-content}
  .marquee:hover .marquee-track{animation-play-state:paused}
  .marquee-track span{font-family:'JetBrains Mono',monospace;font-size:14px;color:var(--faint);letter-spacing:.03em;display:inline-flex;align-items:center;gap:52px}
  .marquee-track span::after{content:"›";color:var(--teal);font-weight:600}
  @keyframes scroll{to{transform:translateX(-50%)}}
  section{padding:96px 0;position:relative}
  .sec-head{max-width:640px;margin:0 auto 54px;text-align:center}
  .sec-head h2{font-size:clamp(30px,4vw,44px);margin:16px 0 14px}
  .sec-head p{color:var(--muted);font-size:17px}
  .sec-head .eyebrow{justify-content:center}
  .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
  .about-text p{color:var(--muted);margin-bottom:18px;font-size:16.5px}
  .about-text strong{color:var(--ink);font-weight:600}
  .about-visual{position:relative}
  .about-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:8px;position:relative;overflow:hidden}
  .about-frame{position:relative;width:100%;height:380px;border-radius:12px;overflow:hidden;background:var(--bg-2)}
  .about-fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;padding:24px;
    background:radial-gradient(circle at 50% 35%,rgba(45,212,191,.16),transparent 60%),linear-gradient(160deg,var(--surface),var(--bg-2))}
  .about-fallback .fb-shield{width:74px;height:74px;border-radius:18px;background:linear-gradient(135deg,var(--teal),var(--cyan));display:flex;align-items:center;justify-content:center;box-shadow:0 16px 34px -12px rgba(45,212,191,.5)}
  .about-fallback .fb-shield svg{width:40px;height:40px;fill:var(--on-teal)}
  .about-fallback .fb-name{font-family:'Sora',sans-serif;font-weight:700;font-size:20px;color:var(--ink);margin-top:6px}
  .about-fallback .fb-role{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--muted);letter-spacing:.02em}
  .about-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
  .verified{position:absolute;bottom:22px;left:22px;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:11px 15px;display:flex;align-items:center;gap:10px;box-shadow:0 14px 30px -12px var(--shadow)}
  .verified .v-ic{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--teal),var(--cyan));display:flex;align-items:center;justify-content:center}
  .verified .v-ic svg{width:18px;height:18px;fill:var(--on-teal)}
  .verified .v-t{font-weight:600;font-size:13.5px}
  .verified .v-s{font-size:11.5px;color:var(--faint)}
  .about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:26px}
  .astat{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:18px 16px;text-align:center;transition:.25s}
  .astat:hover{border-color:var(--teal);transform:translateY(-3px)}
  .astat .n{font-family:'Sora',sans-serif;font-size:26px;font-weight:700;color:var(--teal)}
  .astat .t{font-size:12px;color:var(--muted);margin-top:4px}
  .price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .price-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:32px 28px;position:relative;transition:.28s;display:flex;flex-direction:column}
  .price-card:hover{transform:translateY(-6px);border-color:var(--faint)}
  .price-card.feat{border-color:var(--teal);background:linear-gradient(180deg,rgba(45,212,191,.06),var(--surface) 42%)}
  .price-card.feat:hover{border-color:var(--teal)}
  .feat-tag{position:absolute;top:18px;right:18px;background:var(--teal);color:var(--on-teal);font-family:'JetBrains Mono',monospace;font-size:10.5px;font-weight:600;letter-spacing:.05em;padding:5px 11px;border-radius:6px;text-transform:uppercase}
  .price-card h3{font-size:21px;margin-bottom:6px}
  .price-card .desc{color:var(--faint);font-size:14px;margin-bottom:22px;min-height:40px}
  .price{display:flex;align-items:baseline;gap:6px;margin-bottom:24px}
  .price .cur{color:var(--muted);font-size:15px;font-weight:600}
  .price .amt{font-family:'Sora',sans-serif;font-size:44px;font-weight:700;line-height:1}
  .feat-list{list-style:none;display:grid;gap:13px;margin-bottom:28px;flex:1}
  .feat-list li{display:flex;gap:11px;font-size:14.5px;color:var(--muted);align-items:flex-start}
  .feat-list li svg{flex-shrink:0;margin-top:3px}
  .price-card .btn{width:100%;justify-content:center}
  .skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
  .skill-col{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:26px 24px;transition:.25s}
  .skill-col:hover{border-color:var(--teal);transform:translateY(-4px)}
  .skill-col .sk-ic{width:44px;height:44px;border-radius:11px;background:rgba(45,212,191,.1);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
  .skill-col .sk-ic svg{width:22px;height:22px;stroke:var(--teal)}
  .skill-col h3{font-size:17px;margin-bottom:16px}
  .skill-col ul{list-style:none;display:grid;gap:10px}
  .skill-col li{font-size:14px;color:var(--muted);display:flex;align-items:center;gap:9px}
  .skill-col li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--teal);flex-shrink:0}
  .test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .test-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:30px 28px;transition:.25s;display:flex;flex-direction:column}
  .test-card:hover{border-color:var(--faint);transform:translateY(-3px)}
  .stars{color:var(--teal);font-size:15px;letter-spacing:2px;margin-bottom:16px}
  .test-card .quote{color:var(--ink);font-size:15px;line-height:1.65;margin-bottom:24px;flex:1}
  .test-author{display:flex;align-items:center;gap:13px}
  .avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--cyan));display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-weight:700;color:var(--on-teal);font-size:18px;flex-shrink:0}
  .test-author .name{font-weight:600;font-size:15px}
  .test-author .role{color:var(--faint);font-size:13px}
  .contact{background:var(--bg-2);border-top:1px solid var(--line)}
  .contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px}
  .contact-info h2{font-size:clamp(30px,4vw,42px);margin:16px 0 16px}
  .contact-info>p{color:var(--muted);font-size:16.5px;margin-bottom:32px}
  .info-row{display:flex;gap:15px;align-items:flex-start;margin-bottom:24px}
  .info-icon{width:44px;height:44px;border-radius:10px;background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--teal)}
  .info-row .k{font-size:13px;color:var(--faint);text-transform:uppercase;letter-spacing:.05em;font-family:'JetBrains Mono',monospace}
  .info-row .v{font-size:16px;color:var(--ink);margin-top:2px}
  /* CONTACT CHANNELS — tile grid */
  .contact-options{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .ch{position:relative;overflow:hidden;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px;transition:transform .28s cubic-bezier(.16,1,.3,1),border-color .28s;cursor:pointer;isolation:isolate;text-align:left;display:block;min-height:150px}
  .ch::before{content:"";position:absolute;left:0;right:0;bottom:0;height:0;background:var(--ch);opacity:.14;transition:height .32s cubic-bezier(.16,1,.3,1);z-index:-1}
  .ch:hover{transform:translateY(-4px);border-color:var(--ch)}
  .ch:hover::before{height:100%}
  .ch:focus-visible{outline:2px solid var(--ch);outline-offset:3px}
  .ch-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:auto}
  .ch-chip{width:46px;height:46px;border-radius:12px;background:var(--ch);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px -8px var(--ch);flex-shrink:0}
  .ch-chip svg{width:24px;height:24px;fill:#fff}
  .ch-go{width:30px;height:30px;border-radius:9px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--faint);transition:.25s;background:var(--bg-2)}
  .ch:hover .ch-go{color:var(--ch);border-color:var(--ch);transform:rotate(-45deg)}
  .ch-go svg{width:15px;height:15px;stroke:currentColor}
  .ch-body{margin-top:36px}
  .ch-k{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ch);font-weight:600;display:flex;align-items:center;gap:8px}
  .ch-v{font-family:'Sora',sans-serif;font-size:18px;font-weight:600;color:var(--ink);margin-top:7px;line-height:1.25;word-break:break-word}
  .ch-sub{font-size:13px;color:var(--muted);margin-top:4px}
  /* featured (whatsapp) spans both columns, horizontal layout */
  .ch.feat{grid-column:1 / -1;min-height:0;display:flex;align-items:center;gap:20px}
  .ch.feat .ch-chip{width:56px;height:56px;border-radius:15px}
  .ch.feat .ch-chip svg{width:30px;height:30px}
  .ch.feat .ch-body{margin-top:0;flex:1}
  .ch.feat .ch-v{font-size:22px}
  .ch.feat .ch-go{margin-left:auto;align-self:center}
  .ch-live{font-size:9.5px;background:var(--ch);color:#fff;border-radius:5px;padding:2px 7px;letter-spacing:.08em;display:inline-flex;align-items:center;gap:5px}
  .ch-live::before{content:"";width:5px;height:5px;border-radius:50%;background:#fff;animation:pulse2 1.6s infinite}
  @keyframes pulse2{50%{opacity:.35}}

  footer{background:var(--bg);border-top:1px solid var(--line);padding:60px 0 30px}
  .foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:44px}
  .foot-brand .logo{margin-bottom:14px}
  .foot-brand p{color:var(--muted);font-size:15px;max-width:300px;margin-bottom:20px}
  .socials{display:flex;gap:11px}
  .socials a{width:40px;height:40px;border-radius:9px;background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:.2s}
  .socials a:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-2px)}
  .socials a svg{width:18px;height:18px}
  .foot-col h4{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);font-family:'JetBrains Mono',monospace;margin-bottom:18px;font-weight:500}
  .foot-col a{display:block;color:var(--muted);font-size:14.5px;margin-bottom:12px;transition:.2s}
  .foot-col a:hover{color:var(--teal)}
  .foot-bottom{border-top:1px solid var(--line);padding-top:26px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
  .foot-bottom p{color:var(--faint);font-size:13.5px}
  .opt-ic.wa{background:rgba(37,211,102,.14)}
  /* WHATSAPP FLOAT + POPUP */
  .wa-float{position:fixed;bottom:26px;right:26px;z-index:60;width:60px;height:60px;border-radius:50%;background:#25d366;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px -6px rgba(37,211,102,.55);transition:.25s}
  .wa-float:hover{transform:scale(1.07) translateY(-2px);box-shadow:0 16px 38px -6px rgba(37,211,102,.65)}
  .wa-float svg{width:32px;height:32px;fill:#fff}
  .wa-float::before{content:"";position:absolute;inset:0;border-radius:50%;background:#25d366;animation:waPing 2.4s ease-out infinite;z-index:-1}
  @keyframes waPing{0%{transform:scale(1);opacity:.55}80%,100%{transform:scale(1.7);opacity:0}}
  .wa-overlay{position:fixed;inset:0;z-index:70;background:rgba(4,8,10,.6);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:flex-end;padding:26px;opacity:0;pointer-events:none;transition:.25s}
  .wa-overlay.open{opacity:1;pointer-events:auto}
  .wa-modal{background:var(--surface);border:1px solid var(--line);border-radius:18px;width:340px;max-width:100%;overflow:hidden;box-shadow:0 30px 80px -20px var(--shadow);transform:translateY(16px) scale(.97);transition:.28s cubic-bezier(.16,1,.3,1);margin-bottom:78px}
  .wa-overlay.open .wa-modal{transform:none}
  .wa-top{background:#075e54;padding:18px 20px;display:flex;align-items:center;gap:13px;position:relative}
  html[data-theme="light"] .wa-top{background:#128c7e}
  .wa-pic{width:46px;height:46px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .wa-pic svg{width:26px;height:26px;fill:#fff}
  .wa-top .wa-name{color:#fff;font-weight:600;font-size:15.5px;line-height:1.2}
  .wa-top .wa-stat{color:rgba(255,255,255,.8);font-size:12.5px;display:flex;align-items:center;gap:6px;margin-top:2px}
  .wa-top .wa-stat::before{content:"";width:7px;height:7px;border-radius:50%;background:#7ee787;display:inline-block}
  .wa-close{position:absolute;top:14px;right:14px;background:rgba(255,255,255,.15);border:0;width:28px;height:28px;border-radius:50%;color:#fff;cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center}
  .wa-close:hover{background:rgba(255,255,255,.28)}
  .wa-chat{padding:24px 20px;background:var(--bg-2);background-image:radial-gradient(var(--line) .8px,transparent .8px);background-size:18px 18px}
  .wa-bubble{background:var(--surface);border:1px solid var(--line);border-radius:4px 14px 14px 14px;padding:13px 15px;font-size:14.5px;color:var(--ink);max-width:90%;box-shadow:0 2px 6px -2px var(--shadow)}
  .wa-bubble .t{font-size:11px;color:var(--faint);margin-top:6px;text-align:right}
  .wa-foot{padding:16px 20px;background:var(--surface)}
  .wa-send{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;background:#25d366;color:#fff;border:0;padding:13px;border-radius:10px;font-weight:600;font-size:15px;cursor:pointer;font-family:inherit;transition:.2s}
  .wa-send:hover{background:#1fb855}
  .wa-send svg{width:20px;height:20px;fill:#fff}
  /* BACK TO TOP */
  .to-top{position:fixed;bottom:26px;left:26px;z-index:55;width:46px;height:46px;border-radius:11px;background:var(--surface);border:1px solid var(--line);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transform:translateY(12px);transition:.25s}
  .to-top.show{opacity:1;pointer-events:auto;transform:none}
  .to-top:hover{color:var(--teal);border-color:var(--teal);transform:translateY(-2px)}
  .to-top svg{width:20px;height:20px;stroke:currentColor}

  .reveal{opacity:0;transform:translateY(26px);transition:.7s cubic-bezier(.16,1,.3,1)}
  .reveal.in{opacity:1;transform:none}
  @media(max-width:920px){
    .hero-inner,.about-grid,.contact-grid{grid-template-columns:1fr;gap:44px}
    .scanner{max-width:460px}
    .price-grid,.test-grid{grid-template-columns:1fr}
    .skills-grid{grid-template-columns:1fr 1fr}
    .foot-grid{grid-template-columns:1fr 1fr}
    .nav-links{position:fixed;top:74px;left:0;right:0;background:var(--bg-2);border-bottom:1px solid var(--line);flex-direction:column;padding:24px 28px;gap:20px;align-items:flex-start;transform:translateY(-130%);transition:.35s;z-index:40}
    .nav-links.open{transform:translateY(0)}
    .burger{display:flex}
  }
  @media(max-width:560px){
    .wrap{padding:0 20px}
    .hero-stats{gap:22px;flex-wrap:wrap}
    .skills-grid{grid-template-columns:1fr}
    .about-stats{grid-template-columns:1fr 1fr 1fr}
    .foot-grid{grid-template-columns:1fr}
    .contact-options{grid-template-columns:1fr}
    .ch{min-height:0}
    .ch-body{margin-top:22px}
    section{padding:72px 0}
  }
  @media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto}.reveal{opacity:1;transform:none}}


/* ---------- Inner pages (blog, pages, and plugin/client-portal pages) ---------- */
.inner-page{padding:130px 0 80px;min-height:60vh}
.wrap.narrow{max-width:820px}
.inner-title{font-family:'Sora',sans-serif;font-weight:700;letter-spacing:-.02em;font-size:clamp(28px,4vw,42px);color:var(--ink);margin-bottom:18px}
.inner-meta{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--faint);margin-bottom:22px}
.inner-thumb{margin-bottom:26px}
.inner-thumb img{width:100%;height:auto;border-radius:14px;border:1px solid var(--line)}
.inner-content{color:var(--muted);font-size:16.5px;line-height:1.7}
.inner-content h2,.inner-content h3{font-family:'Sora',sans-serif;color:var(--ink);margin:28px 0 12px;letter-spacing:-.01em}
.inner-content p{margin-bottom:16px}
.inner-content a{color:var(--teal);text-decoration:underline;text-underline-offset:2px}
.inner-content ul,.inner-content ol{margin:0 0 16px 20px}
.inner-content li{margin-bottom:8px}
.inner-content img{max-width:100%;height:auto;border-radius:12px}
.inner-content blockquote{border-left:3px solid var(--teal);padding-left:18px;margin:20px 0;color:var(--ink)}

/* Style common plugin tables/forms (invoices, client dashboards) to match the theme */
.inner-content table{width:100%;border-collapse:collapse;margin:18px 0;font-size:14.5px}
.inner-content table th,.inner-content table td{border:1px solid var(--line);padding:11px 14px;text-align:left}
.inner-content table th{background:var(--bg-2);color:var(--ink);font-family:'JetBrains Mono',monospace;font-size:12.5px;letter-spacing:.03em;text-transform:uppercase}
.inner-content table td{color:var(--muted)}
.inner-content input:not([type=checkbox]):not([type=radio]),
.inner-content select,
.inner-content textarea{background:var(--surface);border:1px solid var(--line);border-radius:9px;padding:11px 14px;color:var(--ink);font-family:inherit;font-size:15px;width:100%;max-width:420px}
.inner-content input:focus,.inner-content select:focus,.inner-content textarea:focus{outline:0;border-color:var(--teal);box-shadow:0 0 0 3px rgba(45,212,191,.12)}
.inner-content button,
.inner-content input[type=submit],
.inner-content .button{background:var(--teal);color:var(--on-teal);border:0;border-radius:9px;padding:12px 22px;font-weight:600;font-size:15px;cursor:pointer;font-family:inherit;transition:.2s}
.inner-content button:hover,.inner-content input[type=submit]:hover,.inner-content .button:hover{background:var(--teal-soft)}
.pagination,.page-links{margin-top:30px;display:flex;gap:8px;flex-wrap:wrap}
.pagination a,.pagination span,.page-links a,.page-links span{border:1px solid var(--line);border-radius:8px;padding:8px 13px;color:var(--muted);font-size:14px}
.pagination .current{background:var(--teal);color:var(--on-teal);border-color:var(--teal)}

/* ============================================================
   Blog — listing grid + single post (dark/teal, matches site)
   ============================================================ */
.blog-head{max-width:720px;margin:0 auto 44px;text-align:center}
.blog-head .eyebrow{justify-content:center;margin-bottom:14px}
.blog-sub{color:var(--muted);font-size:17px;margin-top:10px}

.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:.28s cubic-bezier(.16,1,.3,1)}
.blog-card:hover{transform:translateY(-5px);border-color:var(--teal)}
.blog-card-link{display:flex;flex-direction:column;height:100%}
.blog-card-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--bg-2)}
.blog-card-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.blog-card:hover .blog-card-thumb img{transform:scale(1.05)}
.blog-card-thumb--ph{display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 40% 30%,rgba(45,212,191,.18),transparent 60%),linear-gradient(160deg,var(--surface),var(--bg-2))}
.blog-card-thumb--ph span{font-family:'Sora',sans-serif;font-size:44px;font-weight:700;color:var(--teal);opacity:.6}
.blog-card-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.blog-card-meta{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.blog-cat{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--teal);background:rgba(45,212,191,.1);border:1px solid rgba(45,212,191,.25);padding:3px 9px;border-radius:6px}
.blog-date{font-size:12.5px;color:var(--faint)}
.blog-card-title{font-family:'Sora',sans-serif;font-size:19px;font-weight:600;line-height:1.3;letter-spacing:-.01em;color:var(--ink);margin:0 0 10px}
.blog-card-excerpt{color:var(--muted);font-size:14.5px;line-height:1.6;margin:0 0 16px;flex:1}
.blog-card-more{font-size:13.5px;font-weight:600;color:var(--teal);transition:.2s}
.blog-card:hover .blog-card-more{letter-spacing:.02em}

.blog-pagination{margin-top:44px;display:flex;justify-content:center}
.blog-pagination .nav-links{display:flex;gap:8px;flex-wrap:wrap}
.blog-pagination a,.blog-pagination .current{border:1px solid var(--line);border-radius:8px;padding:9px 15px;color:var(--muted);font-size:14px;transition:.2s}
.blog-pagination a:hover{border-color:var(--teal);color:var(--teal)}
.blog-pagination .current{background:var(--teal);color:var(--on-teal);border-color:var(--teal)}

/* Single post */
.single-post{max-width:760px;margin:0 auto}
.post-meta-top{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.post-date{font-size:13px;color:var(--faint)}
.post-title{font-family:'Sora',sans-serif;font-size:clamp(30px,5vw,46px);font-weight:700;line-height:1.12;letter-spacing:-.02em;color:var(--ink);margin:0 0 20px}
.post-byline{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:14px;margin-bottom:30px}
.post-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--cyan));display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-weight:700;color:var(--on-teal);font-size:15px}
.post-dot{color:var(--faint)}
.post-hero{margin:0 0 34px;border-radius:16px;overflow:hidden;border:1px solid var(--line)}
.post-hero img{width:100%;height:auto;display:block}
.post-content{font-size:17px;line-height:1.8}
.post-content > *{margin-bottom:22px}
.post-content h2{font-size:26px;margin:38px 0 14px}
.post-content h3{font-size:21px;margin:30px 0 12px}
.post-tags{margin-top:34px;display:flex;gap:8px;flex-wrap:wrap}
.post-tags a{font-size:12.5px;color:var(--muted);background:var(--bg-2);border:1px solid var(--line);padding:5px 12px;border-radius:7px;transition:.2s}
.post-tags a:hover{border-color:var(--teal);color:var(--teal)}
.post-foot{margin-top:40px;padding-top:24px;border-top:1px solid var(--line)}
.post-back{color:var(--teal);font-weight:600;font-size:15px}
.post-back:hover{color:var(--teal-soft)}

@media(max-width:900px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr}}
