:root{
  --bg:#071523;
  --bg-2:#0b1e2d;
  --bg-3:#0f2a3e;
  --text:#f2f5f8;
  --muted:#b7c2cf;
  --accent:#ffd65a;
  --accent-2:#6be7ff;
  --accent-3:#c7a94e;
  --card:rgba(9,24,38,0.82);
  --border:rgba(255,255,255,0.08);
  --shadow:0 20px 50px rgba(2,10,18,0.45);
  --radius:20px;
  --max:1120px;
  --pad:clamp(1rem,2.2vw,1.8rem);
  --gap:clamp(1.5rem,2.6vw,2.5rem);
  --glow:0 0 40px rgba(107,231,255,0.15);
}

*{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  color:var(--text);
  line-height:1.6;
  background:linear-gradient(120deg,var(--bg),var(--bg-2) 40%,var(--bg-3));
  min-height:100vh;
  font-family:"Sora","Sora Fallback",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,sans-serif;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

body.loading{
  overflow:hidden;
}

a{
  color:var(--accent);
  text-decoration:none;
}

a:hover{
  color:#fff;
}

a:focus-visible,button:focus-visible{
  outline:3px solid var(--accent);
  outline-offset:3px;
}

#loader{
  position:fixed;
  inset:0;
  display:grid;
  place-items:center;
  background:rgba(7,21,35,0.88);
  backdrop-filter:blur(12px);
  z-index:3000;
  transition:opacity .5s ease, visibility .5s ease;
}

#loader.hidden{
  opacity:0;
  visibility:hidden;
}

.loader-ring{
  width:56px;
  height:56px;
  border-radius:50%;
  border:3px solid rgba(255,255,255,0.15);
  border-top-color:var(--accent);
  box-shadow:var(--glow);
  animation:spin 1s linear infinite;
}

.nav{
  position:sticky;
  top:0;
  z-index:1200;
  background:rgba(6,18,30,0.72);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}

.nav-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:.8rem var(--pad);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}

.brand{
  font-family:"Space Grotesk",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,sans-serif;
  font-weight:700;
  letter-spacing:.03em;
  color:#fff;
  cursor:pointer;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
}

.nav-menu{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:1.2rem;
  flex-wrap:wrap;
}

.nav-menu a{
  font-weight:600;
  color:var(--muted);
  padding:.35rem .25rem;
  border-bottom:2px solid transparent;
  transition:color .2s ease, border-color .2s ease;
  cursor:pointer;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  user-select:none;
  -webkit-user-select:none;
}

.nav-menu a.active,
.nav-menu a[aria-current="page"]{
  color:#fff;
  border-color:var(--accent);
}

.nav-toggle{
  display:none;
  background:rgba(255,255,255,0.06);
  border:1px solid var(--border);
  color:#fff;
  border-radius:999px;
  padding:.45rem .95rem;
  font:inherit;
  font-weight:600;
  cursor:pointer;
}

.hero{
  padding:clamp(2rem,4vw,3.5rem) var(--pad) 1rem;
}

.hero-inner{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:auto 1fr;
  gap:clamp(1rem,3vw,2.5rem);
  align-items:center;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:clamp(1.5rem,3vw,2.5rem);
  box-shadow:var(--shadow);
}

/* ── Self-hosted fonts (eliminates Google Fonts CDN chain) ─ */
@font-face{
  font-family:"Sora";
  font-style:normal;
  font-weight:400 600;
  font-display:swap;
  src:url("../fonts/sora-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Sora";
  font-style:normal;
  font-weight:400 600;
  font-display:swap;
  src:url("../fonts/sora-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Space Grotesk";
  font-style:normal;
  font-weight:600 700;
  font-display:swap;
  src:url("../fonts/space-grotesk-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Space Grotesk";
  font-style:normal;
  font-weight:600 700;
  font-display:swap;
  src:url("../fonts/space-grotesk-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
/* Adjusted fallback metrics — minimises CLS during font-display:swap */
@font-face{
  font-family:"Space Grotesk Fallback";
  src:local("Arial"),local("Helvetica Neue"),local("Helvetica");
  ascent-override:88%;
  descent-override:22%;
  line-gap-override:0%;
  size-adjust:100%;
}
@font-face{
  font-family:"Sora Fallback";
  src:local("Arial"),local("Helvetica Neue"),local("Helvetica");
  ascent-override:90%;
  descent-override:21%;
  line-gap-override:0%;
  size-adjust:96%;
}

.hero-media img{
  width:120px;
  height:120px;
  border-radius:50%;
  border:3px solid var(--accent-3);
  box-shadow:0 0 22px rgba(255,214,90,0.2);
  object-fit:cover;
}

.name{
  font-family:"Space Grotesk","Space Grotesk Fallback",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,sans-serif;
  font-size:clamp(1.6rem,2.6vw,2.4rem);
  font-weight:700;
  color:var(--accent);
  margin-bottom:.2rem;
}

.name a{
  color:inherit;
}

h1,h2,h3{
  font-family:"Space Grotesk","Space Grotesk Fallback",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,sans-serif;
  margin:0 0 .75rem 0;
}

h1{
  font-size:clamp(1.5rem,2.6vw,2.4rem);
  line-height:1.2;
}

h2{
  font-size:clamp(1.2rem,2vw,1.6rem);
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--accent);
}

.section-title{
  margin-bottom:1rem;
  border-bottom:1px solid var(--border);
  padding-bottom:.5rem;
}

.subtitle{
  color:var(--muted);
  margin:0;
}

.hero-cta{
  margin-top:1rem;
}

.libutton{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.45rem 1.2rem;
  text-align:center;
  border-radius:999px;
  background-color:#0A66C2;
  color:#fff !important;
  font-weight:600;
  transition:transform .2s ease, box-shadow .2s ease;
}

.libutton:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 18px rgba(10,102,194,0.3);
}

main{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad) 4rem;
  display:grid;
  gap:var(--gap);
}

.panel{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:clamp(1.2rem,2.4vw,2rem);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
  content-visibility:auto;
  contain-intrinsic-size:1100px 800px;
  scroll-margin-top:80px;
}

/* Ensure hidden sections are truly hidden even with content-visibility */
section[hidden]{
  display:none !important;
}

.panel::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,rgba(107,231,255,0.08),transparent 40%),linear-gradient(200deg,rgba(255,214,90,0.08),transparent 45%);
  opacity:.6;
  pointer-events:none;
}

.content-flow > p{
  margin-top:0;
}

.reveal{
  opacity:0;
  transform:translateY(20px);
  transition:opacity .6s ease, transform .6s ease;
}

.reveal.in-view{
  opacity:1;
  transform:translateY(0);
}

.featured-posts-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1.5rem;
}

.featured-card{
  background:rgba(10,24,38,0.75);
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--border);
  box-shadow:0 12px 30px rgba(0,0,0,0.35);
  transition:transform .3s ease, box-shadow .3s ease;
  display:flex;
  flex-direction:column;
}

.featured-card:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 38px rgba(0,0,0,0.45);
}

.featured-card img{
  width:100%;
  height:clamp(150px,18vw,220px);
  object-fit:cover;
}

.featured-card video{
  width:100%;
  height:clamp(150px,18vw,220px);
  object-fit:cover;
  background:#000;
}

.featured-card .video-thumb{
  display:block;
  position:relative;
}

.featured-card .video-thumb::after{
  content:"▶";
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:56px;
  height:56px;
  background:rgba(0,0,0,.7);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  color:#fff;
  pointer-events:none;
  transition:background .2s ease;
}

.featured-card .video-thumb:hover::after{
  background:rgba(255,0,0,.85);
}

.featured-card-content{
  padding:1.2rem;
  display:flex;
  flex-direction:column;
  gap:.6rem;
}

.featured-card-content h3{
  margin:0;
  font-size:clamp(1rem,1.4vw,1.15rem);
}

.featured-card-content p{
  margin:0;
  color:var(--muted);
}

.timeline{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:.8rem;
}

.timeline li{
  padding:.6rem .9rem;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:12px;
}

#skills p{
  margin:0;
}

.site-footer{
  max-width:var(--max);
  margin:0 auto 2.5rem;
  padding:0 var(--pad);
  text-align:center;
  color:var(--muted);
}

.footer-profiles{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  align-items:center;
  justify-content:center;
  margin-top:1rem;
}

.footer-profiles a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border-radius:999px;
  box-shadow:0 0 0 2px currentColor inset;
  color:var(--accent);
  opacity:.9;
  transition:transform .15s ease, opacity .15s ease;
}

.footer-profiles a:hover{
  transform:translateY(-2px);
  opacity:1;
}

@media (max-width:900px){
  .hero-inner{
    grid-template-columns:1fr;
    text-align:left;
  }
  .nav-toggle{
    display:inline-flex;
  }
  .nav-menu{
    position:absolute;
    top:100%;
    right:0;
    left:0;
    background:rgba(6,18,30,0.98);
    flex-direction:column;
    align-items:flex-start;
    padding:1rem var(--pad);
    gap:.8rem;
    display:none;
  }
  .nav-menu.open{
    display:flex;
  }
}

@media (prefers-reduced-motion:reduce){
  *{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .reveal{
    opacity:1;
    transform:none;
  }
}

@keyframes spin{
  to{transform:rotate(360deg)}
}

/* ── Testimonials ─────────────────────────────────────── */
.testimonials-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.25rem;
}

.testimonial-card{
  background:rgba(10,24,38,0.75);
  border-radius:16px;
  border:1px solid var(--border);
  padding:1.4rem 1.4rem 1.1rem;
  display:flex;
  flex-direction:column;
  gap:.8rem;
  position:relative;
  transition:transform .3s ease, box-shadow .3s ease;
}

.testimonial-card:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 36px rgba(0,0,0,0.4);
}

.testimonial-card::before{
  content:"\201C";
  position:absolute;
  top:-.1rem;
  left:1rem;
  font-size:4rem;
  line-height:1;
  color:var(--accent);
  opacity:.35;
  font-family:Georgia,serif;
  pointer-events:none;
}

.testimonial-text{
  color:var(--muted);
  font-size:.95rem;
  line-height:1.65;
  margin:0;
  padding-top:.5rem;
}

.testimonial-author{
  display:flex;
  flex-direction:column;
  gap:.15rem;
  border-top:1px solid var(--border);
  padding-top:.75rem;
  margin-top:auto;
}

.testimonial-author strong{
  color:var(--accent-2);
  font-size:.95rem;
}

.testimonial-author span{
  color:var(--muted);
  font-size:.82rem;
}

/* ── Skill tags ───────────────────────────────────────── */
.skill-tags{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  margin:0;
  padding:0;
  list-style:none;
}

.skill-tag{
  display:inline-flex;
  align-items:center;
  gap:.3rem;
  padding:.35rem .85rem;
  background:rgba(107,231,255,0.08);
  border:1px solid rgba(107,231,255,0.2);
  border-radius:999px;
  font-size:.85rem;
  font-weight:600;
  color:var(--accent-2);
  transition:background .2s ease, transform .15s ease;
}

.skill-tag:hover{
  background:rgba(107,231,255,0.16);
  transform:translateY(-1px);
}

/* ── Experience descriptions ─────────────────────────── */
.timeline-desc{
  margin:.45rem 0 0;
  color:var(--muted);
  font-size:.88rem;
  line-height:1.6;
}

/* ── LinkedIn Articles ────────────────────────────────── */
.articles-list{
  list-style:none;
  margin:.5rem 0 0;
  padding:0;
  display:grid;
  gap:.8rem;
}

.articles-list li{
  padding:.6rem .9rem;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:12px;
}

.articles-list .article-meta{
  display:block;
  font-size:.8rem;
  color:var(--muted);
  margin-top:.2rem;
}

.publications-sub-heading{
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--accent-3);
  font-weight:700;
  margin:1.2rem 0 .6rem;
  font-family:"Space Grotesk",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,sans-serif;
}

/* ── Visually hidden (accessible) ─────────────────────── */
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* ── Site Search ──────────────────────────────────────── */
#search-results:not([hidden]){
  display:block;
}

.search-form{
  display:flex;
  gap:.5rem;
  margin-bottom:1rem;
}

.search-input{
  flex:1;
  padding:.65rem 1rem;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,0.06);
  color:var(--text);
  font:inherit;
  font-size:1rem;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease;
}

.search-input::placeholder{
  color:var(--muted);
  opacity:.7;
}

.search-input:focus{
  border-color:var(--accent-2);
  box-shadow:0 0 0 3px rgba(107,231,255,0.18);
}

.search-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(107,231,255,0.1);
  color:var(--accent-2);
  cursor:pointer;
  transition:background .2s ease, transform .15s ease;
}

.search-btn:hover{
  background:rgba(107,231,255,0.22);
  transform:translateY(-1px);
}

.search-count{
  color:var(--muted);
  font-size:.9rem;
  margin:0 0 .75rem;
}

.search-results-list{
  display:grid;
  gap:.75rem;
}

.search-result-card{
  padding:.9rem 1.1rem;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:12px;
  cursor:pointer;
  transition:background .2s ease, transform .2s ease, box-shadow .2s ease;
}

.search-result-card:hover{
  background:rgba(107,231,255,0.07);
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(0,0,0,0.3);
}

.search-result-card h3{
  margin:0 0 .35rem;
  font-size:1rem;
  color:var(--accent);
}

.search-result-card p{
  margin:0;
  color:var(--muted);
  font-size:.88rem;
  line-height:1.6;
}

.search-result-card mark{
  background:rgba(255,214,90,0.25);
  color:var(--accent);
  border-radius:2px;
  padding:0 2px;
}

.search-no-results{
  text-align:center;
  padding:2rem 1rem;
  color:var(--muted);
}

.search-no-results svg{
  display:block;
  margin:0 auto .75rem;
  opacity:.4;
}

/* ═══ Contact Form ═══ */
.contact-form{
  margin-top:1.5rem;
  display:grid;
  gap:1rem;
  max-width:640px;
}

.form-group{
  display:flex;
  flex-direction:column;
  gap:.35rem;
}

.form-group label{
  font-size:.88rem;
  font-weight:600;
  color:var(--accent-2);
}

.form-group input,
.form-group textarea{
  padding:.65rem .85rem;
  border:1px solid var(--border);
  border-radius:10px;
  background:rgba(255,255,255,0.04);
  color:var(--text);
  font-family:inherit;
  font-size:.95rem;
  line-height:1.5;
  transition:border-color .2s, box-shadow .2s;
}

.form-group input:focus,
.form-group textarea:focus{
  outline:none;
  border-color:var(--accent-2);
  box-shadow:0 0 0 3px rgba(107,231,255,0.15);
}

.form-group input::placeholder,
.form-group textarea::placeholder{
  color:var(--muted);
  opacity:.6;
}

.contact-submit-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.7rem 1.8rem;
  border:none;
  border-radius:999px;
  background:linear-gradient(135deg,var(--accent),var(--accent-3));
  color:#111;
  font-family:inherit;
  font-size:.92rem;
  font-weight:700;
  cursor:pointer;
  transition:transform .2s, box-shadow .2s;
  width:fit-content;
}

.contact-submit-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(255,214,90,0.3);
}

.form-status{
  font-size:.88rem;
  margin:.5rem 0 0;
}

.form-success{
  color:#4ade80;
}

.form-error{
  color:#f87171;
}

/* ═══ Footer Legal Nav ═══ */
.footer-legal{
  margin-top:.75rem;
  font-size:.82rem;
  color:var(--muted);
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:.4rem;
}

.footer-legal a{
  color:var(--muted);
  text-decoration:underline;
  text-underline-offset:2px;
  transition:color .2s;
}

.footer-legal a:hover{
  color:var(--accent);
}

.footer-legal span{
  color:var(--border);
}

/* ═══ Cookie Consent Banner ═══ */
.cookie-consent{
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  z-index:3000;
  background:rgba(11,30,45,0.97);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-top:1px solid var(--border);
  padding:1rem clamp(1rem,3vw,2rem);
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:.75rem 1.5rem;
  font-size:.85rem;
  color:var(--muted);
  box-shadow:0 -4px 30px rgba(0,0,0,0.4);
}

.cookie-consent[hidden]{
  display:none !important;
}

.cookie-consent p{
  margin:0;
  max-width:680px;
  line-height:1.5;
}

.cookie-consent a{
  color:var(--accent-2);
  text-decoration:underline;
}

.cookie-consent-actions{
  display:flex;
  gap:.5rem;
  flex-shrink:0;
}

.cookie-btn{
  padding:.5rem 1.2rem;
  border:none;
  border-radius:999px;
  font-family:inherit;
  font-size:.82rem;
  font-weight:600;
  cursor:pointer;
  transition:transform .15s, box-shadow .15s;
}

.cookie-btn:hover{
  transform:translateY(-1px);
}

.cookie-btn-accept{
  background:linear-gradient(135deg,var(--accent),var(--accent-3));
  color:#111;
}

.cookie-btn-accept:hover{
  box-shadow:0 4px 16px rgba(255,214,90,0.35);
}

.cookie-btn-reject{
  background:rgba(255,255,255,0.08);
  color:var(--muted);
  border:1px solid var(--border);
}

.cookie-btn-reject:hover{
  background:rgba(255,255,255,0.12);
  color:var(--text);
}

/* ═══ Legal Page Sections ═══ */
#privacy-policy h3,
#terms h3,
#disclaimer h3{
  font-family:"Space Grotesk","Space Grotesk Fallback",system-ui,sans-serif;
  font-size:1.05rem;
  color:var(--accent-2);
  margin:1.6rem 0 .5rem;
}

#privacy-policy ul.timeline li,
#terms ul.timeline li,
#disclaimer ul.timeline li{
  font-size:.92rem;
}


