/* =========================================================
   Bashar Kokash — Personal landing page
   Layout: warm/human (concept 4) · Palette: corporate navy
   "A few figures", pull quote & footer blended from editorial
   ========================================================= */

:root{
  --bg:#eef1f5;        /* cool page background */
  --card:#ffffff;      /* surfaces */
  --ink:#16233a;       /* headings / primary text */
  --muted:#5c6878;     /* secondary text */
  --navy:#1f4e79;      /* primary corporate accent */
  --navy-deep:#163a5c; /* hover / depth */
  --navy-soft:#cfe0f1; /* tints, icon backgrounds */
  --steel:#3a6ea5;     /* secondary accent */
  --line:#dde3ea;      /* hairlines / borders */
  --shadow:rgba(20,45,80,.18);
  --header-bg:rgba(238,241,245,.82);
  --texture:rgba(31,78,121,.05);
}
html[data-theme="dark"]{
  --bg:#0e1620;
  --card:#172230;
  --ink:#e9eef4;
  --muted:#9aa7b6;
  --navy:#6aa9e6;
  --navy-deep:#5394d4;
  --navy-soft:#1d314a;
  --steel:#4a7ba8;
  --line:#24323f;
  --shadow:rgba(0,0,0,.55);
  --header-bg:rgba(14,22,32,.82);
  --texture:rgba(120,170,230,.06);
}
html{transition:background-color .3s ease}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  background-color:var(--bg);color:var(--ink);
  background-image:radial-gradient(var(--texture) 1px,transparent 1px);
  background-size:26px 26px;
  font-family:"Inter",sans-serif;line-height:1.65;font-size:18px;
  -webkit-font-smoothing:antialiased;
  width:100%;max-width:100%;overflow-x:hidden;
  transition:background-color .3s ease,color .3s ease;
}
img{max-width:100%;height:auto}
a{color:inherit}
.serif,h1,h2,h3,h4,blockquote{font-family:"Newsreader",serif}
.wrap{max-width:1080px;margin:0 auto;padding:0 30px}
.label{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--navy);font-weight:600}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* skip link */
.skip-link{position:fixed;top:-60px;left:16px;z-index:100;background:var(--navy);color:#fff;
  padding:11px 18px;border-radius:8px;font-size:.9rem;font-weight:500;text-decoration:none;transition:top .2s}
.skip-link:focus{top:16px}

/* visible keyboard focus */
:focus{outline:none}
a:focus-visible,button:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--navy);outline-offset:3px;border-radius:6px}

/* anchor offset so headings clear the sticky header */
[id]{scroll-margin-top:92px}

/* ---------- SCROLL PROGRESS ---------- */
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:60;background:linear-gradient(90deg,var(--steel),var(--navy));transition:width .08s linear}

/* ---------- NAV ---------- */
header{position:sticky;top:0;z-index:50;background:var(--header-bg);backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
header.scrolled{border-color:var(--line)}
nav{display:flex;justify-content:space-between;align-items:center;padding:20px 0}
nav .brand{display:flex;align-items:center;gap:12px;font-family:"Newsreader",serif;font-size:1.25rem;font-weight:500;text-decoration:none}
nav .dot{width:34px;height:34px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:.9rem;font-weight:600;font-family:"Inter"}
.nav-right{display:flex;align-items:center;gap:6px}
nav .links a{text-decoration:none;color:var(--muted);margin-left:26px;font-size:.9rem;transition:color .2s;position:relative}
nav .links a:hover{color:var(--navy)}
nav .links a.active{color:var(--navy)}
nav .links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--navy);border-radius:2px}

/* theme toggle */
.theme-btn{margin-left:14px;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:var(--card);color:var(--ink);cursor:pointer;display:grid;place-items:center;transition:.2s}
.theme-btn:hover{border-color:var(--navy);color:var(--navy)}
.theme-btn .i-moon{display:none}
html[data-theme="dark"] .theme-btn .i-sun{display:none}
html[data-theme="dark"] .theme-btn .i-moon{display:block}
.menu-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.menu-btn span{width:24px;height:2px;background:var(--ink);transition:.3s}
.menu-btn[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-btn[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-btn[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:720px){
  .menu-btn{display:flex;position:relative;z-index:90}
  .theme-btn{position:relative;z-index:90}
  /* backdrop-filter on an ancestor traps fixed children — drop it on mobile */
  header{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--bg)}
  nav .links{
    position:fixed;inset:0;z-index:80;background:var(--bg);
    flex-direction:column;display:flex;justify-content:center;align-items:stretch;gap:6px;
    padding:88px 34px 40px;border:none;
    opacity:0;visibility:hidden;transform:translateY(-10px);pointer-events:none;
    transition:opacity .3s ease,transform .3s ease,visibility .3s;
  }
  nav .links.open{opacity:1;visibility:visible;transform:none;pointer-events:auto}
  nav .links a{margin:0;padding:20px 4px;border-bottom:1px solid var(--line);
    font-family:"Newsreader",serif;font-size:1.75rem;color:var(--ink)}
  nav .links a.active{color:var(--navy)}
  nav .links a.active::after{display:none}
  body.menu-open{overflow:hidden}
}

/* ---------- HERO ---------- */
.hero{padding:80px 0 70px;display:grid;grid-template-columns:1.4fr .9fr;gap:60px;align-items:center}
@media(max-width:820px){.hero{grid-template-columns:1fr;gap:40px;padding:54px 0 50px}}
.hero h1{font-weight:400;font-size:clamp(2.5rem,6vw,4.6rem);line-height:1.05;letter-spacing:-.01em;margin-top:22px}
.hero h1 em{font-style:italic;color:var(--navy)}
.hero .intro{margin-top:26px;font-size:1.16rem;color:var(--muted);max-width:48ch}
.pills{margin-top:30px;display:flex;gap:10px;flex-wrap:wrap}
.pill{background:var(--card);border:1px solid var(--line);border-radius:30px;padding:9px 18px;font-size:.85rem;color:var(--ink)}
.pill.fill{background:var(--navy);color:#fff;border-color:var(--navy)}
/* staggered hero entrance */
.hero-copy.reveal{transition-delay:.05s}
.hero .portrait.reveal{transition-delay:.18s}

.portrait{background:var(--card);border:1px solid var(--line);border-radius:28px;padding:30px;box-shadow:0 18px 44px -28px rgba(0,0,0,.14)}
.portrait .avatar{width:100%;aspect-ratio:1;border-radius:20px;overflow:hidden;background:var(--line);
  display:grid;place-items:center;font-family:"Newsreader",serif;font-size:3.6rem;color:#fff;font-weight:500;letter-spacing:.04em}
.portrait .avatar img{width:100%;height:100%;object-fit:cover;object-position:center 22%;display:block}
.portrait .pmeta{margin-top:22px}
.portrait .row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px dashed var(--line);font-size:.92rem}
.portrait .row:last-child{border-bottom:none}
.portrait .row span:first-child{color:var(--muted)}
.portrait .row span:last-child{font-weight:500}

/* ---------- SECTION SCAFFOLD ---------- */
section{padding:74px 0}
.shead{text-align:center;margin-bottom:50px}
.shead h2{font-weight:400;font-size:clamp(2rem,4.6vw,3rem);line-height:1.1;margin-top:14px}
.shead h2 em{font-style:italic;color:var(--navy)}
.shead p{color:var(--muted);max-width:52ch;margin:14px auto 0}

/* ---------- APPROACH ---------- */
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(max-width:760px){.values{grid-template-columns:1fr}}
.vcard{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:32px;transition:transform .25s,box-shadow .25s}
.vcard:hover{transform:translateY(-5px);box-shadow:0 22px 40px -26px var(--shadow)}
.vcard .ic{width:50px;height:50px;border-radius:14px;background:var(--navy-soft);color:var(--navy);display:grid;place-items:center;font-size:1.4rem;margin-bottom:18px}
.vcard h3{font-weight:500;font-size:1.5rem;margin-bottom:8px}
.vcard p{color:var(--muted);font-size:1rem}

/* ---------- JOURNEY / TIMELINE ---------- */
.timeline{max-width:780px;margin:0 auto;position:relative}
.timeline::before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:var(--line)}
.tl{position:relative;padding:0 0 40px 46px}
.tl:last-child{padding-bottom:0}
.tl::before{content:"";position:absolute;left:4px;top:6px;width:16px;height:16px;border-radius:50%;background:var(--navy);border:3px solid var(--bg);box-shadow:0 0 0 2px var(--navy-soft)}
.tl .when{color:var(--navy);font-weight:600;font-size:.85rem;letter-spacing:.04em}
.tl h3{font-weight:500;font-size:1.5rem;margin-top:4px}
.tl .co{color:var(--muted);font-size:.95rem;margin-top:2px}
.tl ul{list-style:none;margin-top:13px;display:flex;flex-direction:column;gap:8px}
.tl li{padding-left:20px;position:relative;color:var(--ink);font-size:.98rem}
.tl li::before{content:"›";position:absolute;left:0;color:var(--navy);font-weight:700}
.tl li strong{color:var(--navy);font-weight:600}

/* ---------- LEADERSHIP & PEOPLE MANAGEMENT ---------- */
.lead-body{max-width:680px;margin:0 auto;text-align:center}
.lead-body p{font-size:1.2rem;line-height:1.7;color:var(--ink)}
.lead-body p + p{margin-top:22px}
.lead-body p:last-child{color:var(--muted)}
@media(max-width:640px){
  .lead-body{text-align:left}
  .lead-body p{font-size:1.08rem}
}

/* ---------- EXPERTISE & CREDENTIALS ---------- */
.tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:820px;margin:0 auto 44px}
.tags span{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:10px 16px;font-size:.9rem;color:var(--ink);transition:.2s}
.tags span:hover{border-color:var(--navy);color:var(--navy)}
.creds{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:920px;margin:0 auto}
@media(max-width:760px){.creds{grid-template-columns:1fr}}
.cred-card{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:30px}
.cred-card .label{display:block;margin-bottom:18px}
.cred-item{margin-bottom:18px}
.cred-item:last-child{margin-bottom:0}
.cred-item h4{font-family:"Inter";font-weight:600;font-size:1rem;line-height:1.4}
.cred-item p{color:var(--muted);font-size:.9rem;margin-top:3px}
.cred-list{color:var(--muted);font-size:.98rem;line-height:1.7}

/* ---------- A FEW FIGURES (editorial blend) ---------- */
.sec-head{display:grid;grid-template-columns:1fr 2.2fr;gap:40px;align-items:end;margin-bottom:44px}
@media(max-width:680px){.sec-head{grid-template-columns:1fr;gap:10px}}
.sec-head h2{font-weight:400;font-size:clamp(1.9rem,4vw,2.7rem);letter-spacing:-.01em;line-height:1.1}
.sec-head .lead{color:var(--muted)}
.figures{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line);border:1px solid var(--line);border-radius:20px;overflow:hidden}
@media(max-width:680px){.figures{grid-template-columns:1fr}}
.figures .fig{background:var(--card);padding:44px 34px}
.figures .fig .n{font-weight:400;font-size:clamp(2.6rem,5vw,3.6rem);letter-spacing:-.02em;line-height:1;color:var(--navy)}
.figures .fig .d{margin-top:14px;color:var(--muted);font-size:.97rem}

/* ---------- PULL QUOTE (editorial blend) ---------- */
.pull{text-align:center;padding:100px 0}
.pull blockquote{font-style:italic;font-weight:300;font-size:clamp(1.7rem,4vw,2.7rem);line-height:1.35;max-width:24ch;margin:0 auto;color:var(--ink)}
.pull cite{display:block;margin-top:26px;font-style:normal;color:var(--muted);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase}

/* ---------- FOOTER (editorial blend, corporate skin) ---------- */
footer{background:var(--card);border-top:1px solid var(--line);border-radius:40px 40px 0 0;margin-top:20px;padding:74px 0 60px}
.foot{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:34px}
footer h2{font-weight:400;font-size:clamp(2rem,5vw,3.2rem);letter-spacing:-.01em;line-height:1.05}
footer h2 em{font-style:italic;color:var(--navy)}
.foot-links{display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.foot-links a{text-decoration:none;color:var(--ink);font-size:1.05rem;display:inline-flex;gap:8px;border-bottom:1px solid transparent;transition:border-color .2s,color .2s}
.foot-links a span{color:var(--navy)}
.foot-links a:hover{color:var(--navy);border-color:var(--navy)}
@media(max-width:560px){.foot{flex-direction:column;align-items:flex-start}.foot-links{align-items:flex-start}}
.seo-text{margin-top:48px;max-width:760px;color:var(--muted);font-size:.82rem;line-height:1.7;opacity:.85}
.colophon{margin-top:22px;color:var(--muted);font-size:.78rem;letter-spacing:.03em}

/* ---------- BACK TO TOP ---------- */
.to-top{
  position:fixed;right:24px;bottom:24px;z-index:60;
  width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;
  background:var(--navy);color:#fff;display:grid;place-items:center;
  box-shadow:0 12px 26px -10px var(--shadow);
  opacity:0;visibility:hidden;transform:translateY(14px);
  transition:opacity .3s ease,transform .3s ease,visibility .3s,background .2s;
}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{background:var(--navy-deep);transform:translateY(-3px)}
.to-top:active{transform:translateY(-1px)}
@media(prefers-reduced-motion:reduce){.to-top{transition:opacity .2s,visibility .2s}.to-top:hover{transform:none}}
@media(max-width:560px){.to-top{right:16px;bottom:16px;width:44px;height:44px}}

/* ---------- EMAIL COPY FEEDBACK ---------- */
.foot-links a.copied{color:var(--navy);border-color:var(--navy)}
.foot-links a.copied span{transform:none}

/* ---------- LARGER TAP TARGETS (touch) ---------- */
@media(max-width:720px){
  nav .links a{min-height:44px;display:flex;align-items:center}
  .foot-links a{min-height:44px;display:inline-flex;align-items:center}
  .theme-btn{width:44px;height:44px}
  .menu-btn{min-width:44px;min-height:44px;justify-content:center;align-items:center}
  .tags span{padding:12px 16px}
}

/* ============================================================
   MOBILE REDESIGN (≤640px)
   ============================================================ */
@media(max-width:640px){
  body{font-size:17px}
  section{padding:50px 0}
  .shead{margin-bottom:32px}
  .shead p{font-size:.98rem}

  /* hero */
  .hero{padding:32px 0 28px;gap:26px}
  .hero h1{margin-top:12px;line-height:1.08}
  .hero .intro{margin-top:18px;font-size:1.08rem}

  /* pills → edge-to-edge horizontal scroll */
  .pills{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;
    margin:24px -30px 0;padding:0 30px 4px}
  .pills::-webkit-scrollbar{display:none}
  .pill{flex:0 0 auto}

  /* profile card → circular avatar + 2×2 stat grid */
  .portrait{padding:26px 24px;border-radius:24px}
  .portrait .avatar{width:150px;height:150px;aspect-ratio:auto;border-radius:50%;margin:0 auto 4px}
  .portrait .avatar img{object-position:center}
  .portrait .pmeta{margin-top:20px;display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
  .portrait .row{flex-direction:column;align-items:flex-start;gap:3px;
    border-bottom:none;border-top:1px solid var(--line);padding:13px 0}
  .portrait .row span:first-child{font-size:.66rem;text-transform:uppercase;letter-spacing:.09em}
  .portrait .row span:last-child{font-size:.98rem;font-weight:600}

  /* cards spacing */
  .vcard{padding:26px}
  .cred-card{padding:24px}

  /* figures compact */
  .figures .fig{padding:30px 26px}
  .figures .fig .d{font-size:.92rem}

  /* pull quote */
  .pull{padding:60px 0}

  /* footer links → full-width tappable buttons */
  footer{padding:54px 0 46px;border-radius:28px 28px 0 0;margin-top:14px}
  .foot{gap:24px}
  .foot-links{align-items:stretch;width:100%;gap:10px}
  .foot-links a{justify-content:space-between;border:1px solid var(--line);
    border-radius:14px;padding:16px 18px;background:var(--card);font-size:1rem}
  .colophon{margin-top:34px}

  .to-top{bottom:18px}
}
@media(max-width:380px){
  .hero h1{font-size:2.1rem}
  .portrait .pmeta{grid-template-columns:1fr}
}
/* keep the top bar from overflowing once 3 controls are present */
@media(max-width:420px){
  nav .brand{font-size:0;gap:0}
  nav .brand .dot{font-size:.9rem}
  .theme-btn{margin-left:8px}
}

/* ---------- HIGH-CONTRAST PREFERENCE ---------- */
@media(prefers-contrast:more){
  :root{--muted:#33404f;--line:#8a98a8;--header-bg:rgba(238,241,245,.96)}
  html[data-theme="dark"]{--muted:#d6e0ea;--line:#667688;--header-bg:rgba(14,22,32,.96)}
  .pill,.tags span,.vcard,.cred-card,.portrait,.figures,.theme-btn{border-width:2px}
  .foot-links a{text-decoration:underline}
  body{background-image:none}
}

/* ---------- PRINT ---------- */
@media print{
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  body{background:#fff;color:#000;font-size:11pt;background-image:none}
  .progress,.to-top,.theme-btn,.menu-btn,header nav .links{display:none !important}
  header{position:static;background:#fff;border:none}
  .wrap{max-width:100%;padding:0}
  section{padding:14px 0;page-break-inside:avoid}
  .hero{padding:0 0 12px;grid-template-columns:1.6fr .8fr;gap:24px}
  .reveal{opacity:1 !important;transform:none !important}
  .vcard,.cred-card,.portrait,.tl,.fig{box-shadow:none !important;page-break-inside:avoid}
  .values,.creds{gap:10px}
  .hero h1{font-size:24pt}
  .shead{margin-bottom:16px}
  h2{font-size:16pt}
  .timeline::before{display:none}
  .tl{padding-left:0}
  .tl::before{display:none}
  a{color:#000;text-decoration:none}
  footer{border-radius:0;border-top:1px solid #ccc;padding:16px 0}
  .pull{padding:24px 0}
  .figures{border:1px solid #ccc}
  .figures .fig{padding:16px}
}
