/* ═══════════════════════════════════════════════════
   ARTHUR VERNET — PORTFOLIO  ·  Iteration 6
   Light · Premium · Airy · SwiftUI-inspired
   ═══════════════════════════════════════════════════ */

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

:root{
  /* ── Light premium palette ── */
  --bg:        #ECEAE4;   /* warm cream */
  --card:      #FAFAF8;   /* near-white */
  --card-alt:  #F2EFE9;   /* tinted card */
  --border:    rgba(0,0,0,.07);
  --border-md: rgba(0,0,0,.14);
  --accent1:   #5B5BD6;   /* deep indigo */
  --accent2:   #0284C7;   /* sky */
  --txt:       #111827;
  --txt-dim:   #4B5563;
  --muted:     #9CA3AF;
  --amber:     #D97706;

  --r: 20px;
  --gap: 18px;
  --font: 'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --spring: cubic-bezier(.175,.885,.32,1.275);
  --ease-out: cubic-bezier(.25,.46,.45,.94);

  --sh-card: 0 2px 8px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);
  --sh-hover: 0 10px 32px rgba(0,0,0,.11), 0 3px 8px rgba(0,0,0,.06);
}

html,body{height:100%}
body{
  background: var(--bg);
  font-family: var(--font);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* ══ PAGE SLIDE ══ */
.page{
  position:fixed;inset:0;
  display:flex;align-items:center;justify-content:center;
  padding:22px;
  transition:transform .72s cubic-bezier(.77,0,.175,1), opacity .5s ease;
  will-change:transform,opacity;
  overflow:auto;
}
.page-hidden{ transform:translateX(100%); opacity:0; pointer-events:none; }
.page-slide-out{ transform:translateX(-100%); opacity:0; pointer-events:none; }

/* ══ LAYOUT ══ */
.page-wrapper{
  display:flex;gap:var(--gap);
  width:100%;max-width:1520px;
  align-items:stretch;
  min-height:calc(100vh - 44px);
}

/* ── SIDEBAR ── */
.sidebar{display:flex;flex-direction:column;align-items:center;gap:18px;width:44px;flex-shrink:0}
.sidebar-brand{display:flex;flex-direction:column;align-items:center;gap:5px}
.brand-icon{color:var(--txt-dim)}
.brand-text{font-size:9px;font-weight:600;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.sidebar-links{display:flex;flex-direction:column;align-items:center;gap:28px;flex:1;justify-content:center}
.sidebar-link{
  writing-mode:vertical-rl;transform:rotate(180deg);
  text-decoration:none;font-size:9px;font-weight:600;
  color:var(--muted);letter-spacing:.09em;text-transform:uppercase;
  transition:color .2s;cursor:pointer;
}
.sidebar-link:hover{color:var(--txt)}

/* ── BENTO GRID (5 columns) ── */
.bento-grid{
  flex:1;display:grid;
  grid-template-columns: 248px 1fr 215px 215px 188px;
  grid-template-rows: 88px 1fr 1fr 220px;
  gap: var(--gap);
}
.card-profile   { grid-column:1;   grid-row:1/5 }
.card-heading   { grid-column:2/5; grid-row:1   }
.card-ranking   { grid-column:5;   grid-row:1/5 }
.card-featured  { grid-column:2;   grid-row:2/4 }
.card-stat-main { grid-column:3/5; grid-row:2/4 }
.card-companies { grid-column:2;   grid-row:4   }
.card-map       { grid-column:3/5; grid-row:4   }

/* ══ BASE CARD ══ */
.card{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  position: relative;
  opacity: 0;
  transform: translateY(16px) scale(.98);
  /* Fallback: if GSAP doesn't load, cards become visible after 1.5s */
  animation: cardFallback 0s 1.5s forwards;
  box-shadow: var(--sh-card);
  transition: box-shadow .3s var(--ease-out), transform .3s var(--ease-out), border-color .3s ease;
  will-change: transform, box-shadow;
}
.card:hover{
  border-color: var(--border-md);
  box-shadow: var(--sh-hover);
}
.corner-mark{position:absolute;top:12px;right:12px;font-size:15px;color:rgba(0,0,0,.1);pointer-events:none;z-index:2}
.shine-layer{position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:9;transition:background .08s ease}

/* ── CARD PEEK ── */
.card-peek{
  display:flex;flex-wrap:wrap;gap:5px;
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .35s var(--spring), opacity .25s ease, margin .25s ease;
}
.card:hover .card-peek{max-height:60px;opacity:1;margin-top:8px}
.peek-tag{
  background:rgba(91,91,214,.07);border:1px solid rgba(91,91,214,.15);
  border-radius:9px;padding:2px 8px;font-size:9px;font-weight:600;color:var(--accent1);
}

/* ══ 1 · PROFILE ══ */
.card-profile{
  background:linear-gradient(168deg,#EAE6F6 0%,#F0ECF8 50%,#F6F4FB 100%);
  border-color:rgba(91,91,214,.12);
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;
  padding:0 20px 24px;
}
/* rings (removed from HTML) */
/* photo */
.photo-wrap{
  position:absolute;top:48px;left:50%;transform:translateX(-50%);z-index:2;
  width:196px;height:196px;border-radius:50%;overflow:hidden;
  border:2.5px solid rgba(255,255,255,.9);
  box-shadow:0 12px 40px rgba(91,91,214,.15),0 0 0 5px rgba(91,91,214,.06);
}
.photo-img{
  width:100%;height:100%;object-fit:cover;object-position:50% 18%;
}
.photo-fallback{width:100%;height:100%;background:linear-gradient(145deg,#C7C2E8,#A8A2D6);display:flex;align-items:center;justify-content:center}
.initials{font-size:52px;font-weight:800;color:rgba(255,255,255,.8);letter-spacing:-2px;user-select:none}

/* name */
.profile-info{position:relative;z-index:3;width:100%}
.greeting{display:block;font-size:16px;font-weight:300;color:var(--muted);margin-bottom:1px}
.pname{font-size:40px;font-weight:800;color:var(--txt);line-height:.95;letter-spacing:-2.5px;margin-bottom:10px}
.pemail{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--muted)}

/* badge */
.badge-wrap{position:absolute;bottom:148px;right:14px;z-index:4}
.badge-circle{
  width:66px;height:66px;border-radius:50%;
  background:rgba(255,255,255,.78);border:1px solid rgba(91,91,214,.18);
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.badge-svg{width:60px;height:60px}
.badge-text{font-size:7.5px;font-family:var(--font);font-weight:600;fill:rgba(91,91,214,.5);letter-spacing:1.2px}
.badge-center{position:absolute;opacity:.7}
.badge-center svg{fill:var(--accent1)}
@keyframes spin{to{transform:rotate(360deg)}}

/* profile actions */
.profile-actions{
  position:relative;z-index:4;width:100%;
  display:flex;align-items:center;gap:8px;
  margin-top:14px;
}
.btn-linkedin{
  flex:1;display:flex;align-items:center;gap:8px;
  background:rgba(91,91,214,.06);
  border:1px solid rgba(91,91,214,.15);
  border-radius:30px;padding:6px 12px 6px 6px;
  text-decoration:none;cursor:pointer;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  transition:background .2s,border-color .2s,transform .2s var(--spring);
}
.btn-linkedin:hover{background:rgba(91,91,214,.14);border-color:rgba(91,91,214,.3);transform:scale(1.02)}
.btn-avatar-wrap{
  width:28px;height:28px;border-radius:50%;overflow:hidden;flex-shrink:0;
  border:1.5px solid rgba(91,91,214,.2);
  background:linear-gradient(145deg,#C7C2E8,#A8A2D6);
}
.btn-avatar-img{width:100%;height:100%;object-fit:cover;object-position:top}
.btn-li-icon{color:var(--accent1);flex-shrink:0}
.btn-linkedin span{font-size:11px;font-weight:600;color:var(--txt-dim)}
.btn-slide{
  width:42px;height:42px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--accent1),#4340b0);
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 4px 14px rgba(91,91,214,.3);
  transition:transform .25s var(--spring),box-shadow .25s ease;
}
.btn-slide:hover{transform:scale(1.1) translateX(2px);box-shadow:0 6px 22px rgba(91,91,214,.45)}
.btn-resume{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,var(--accent1),#4340b0);
  border:none;cursor:pointer;color:#fff;
  border-radius:30px;padding:9px 16px;
  font-family:var(--font);font-size:12px;font-weight:600;
  box-shadow:0 4px 14px rgba(91,91,214,.3);
  transition:transform .25s var(--spring),box-shadow .25s ease;
}
.btn-resume:hover{transform:scale(1.03) translateY(-1px);box-shadow:0 6px 22px rgba(91,91,214,.45)}

/* ══ 2 · HEADING ══ */
.card-heading{
  background:transparent;border:none;box-shadow:none;overflow:visible;
  display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:4px;
}
.card-heading:hover{border:none;box-shadow:none}
.main-title{
  font-size:clamp(50px,5.8vw,84px);font-weight:900;color:var(--txt);
  letter-spacing:-4px;line-height:.9;user-select:none;
}
.title-cursor{font-weight:300;color:var(--accent1);animation:blink 1.2s steps(1) infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes cardFallback{to{opacity:1;transform:none}}
.main-sub{font-size:11px;color:var(--muted);font-weight:500;letter-spacing:.05em;margin-top:6px;text-transform:uppercase}

/* ══ 3 · FEATURED ══ */
.card-featured{
  background:var(--card);
  border-color:rgba(91,91,214,.1);
  cursor:pointer;overflow:hidden;
  display:flex;flex-direction:column;
}
.feat-bg{position:absolute;inset:0;overflow:hidden}
.feat-blob{position:absolute;border-radius:50%;filter:blur(70px)}
.b1{width:220px;height:220px;background:rgba(91,91,214,.05);top:-60px;right:20px;animation:fl1 10s ease-in-out infinite}
.b2{width:160px;height:160px;background:rgba(2,132,199,.03);bottom:-40px;left:40px;animation:fl2 13s ease-in-out infinite}
.b3{width:120px;height:120px;background:rgba(91,91,214,.03);top:30px;left:-20px;animation:fl1 15s ease-in-out infinite reverse}
@keyframes fl1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(14px,-14px) scale(1.06)}}
@keyframes fl2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-10px,10px) scale(1.05)}}

/* featured card — visual layout */
.feat-header{
  position:relative;z-index:3;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px 0;
  flex-shrink:0;
}
.feat-badge{
  display:flex;align-items:center;gap:6px;
  background:rgba(91,91,214,.06);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(91,91,214,.12);border-radius:30px;
  padding:4px 11px;font-size:10px;font-weight:600;color:var(--txt-dim);
}
.feat-badge svg{stroke:var(--accent1)}
.feat-cta-btn{
  display:flex;align-items:center;gap:5px;
  background:rgba(91,91,214,.08);border:1px solid rgba(91,91,214,.18);
  border-radius:20px;padding:5px 13px;
  font-size:10px;font-weight:600;color:var(--accent1);
  cursor:pointer;font-family:var(--font);
  transition:background .2s,transform .18s var(--spring);
}
.feat-cta-btn:hover{background:rgba(91,91,214,.16);transform:scale(1.05)}

/* 4 big stats */
.feat-big-stats{
  position:relative;z-index:3;
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
  padding:12px 16px 0;
  flex-shrink:0;
}
.feat-big-stat{
  background:rgba(91,91,214,.04);border:1px solid rgba(91,91,214,.08);
  border-radius:12px;padding:14px 6px;
  display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;
  transition:background .2s;
}
.feat-big-stat:hover{background:rgba(91,91,214,.08)}
.feat-big-num{font-size:26px;font-weight:900;color:var(--txt);line-height:1;display:flex;align-items:center;justify-content:center}
.feat-big-lbl{font-size:8px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.feat-big-stat.feat-gold{border-color:rgba(217,119,6,.2);background:rgba(217,119,6,.05)}
.feat-big-stat.feat-gold .feat-big-num{color:#D97706}

/* language row */
.feat-langs-row{
  position:relative;z-index:3;
  display:grid;grid-template-columns:repeat(4,1fr);gap:7px;
  padding:10px 16px 0;
  flex-shrink:0;
}
.feat-lang{
  background:rgba(91,91,214,.03);border:1px solid rgba(91,91,214,.06);
  border-radius:10px;padding:10px 4px;
  display:flex;flex-direction:column;align-items:center;gap:5px;
}
.feat-lang-flag{width:22px;height:15px;object-fit:cover;border-radius:2px;display:block}
.feat-lang-lvl{font-size:9px;font-weight:600;color:var(--muted);letter-spacing:.02em}

/* tools row */
.feat-tools-row{
  position:relative;z-index:3;
  display:flex;flex-wrap:wrap;gap:5px;
  padding:10px 16px 16px;
  flex-shrink:0;
  margin-top:auto;
}
.feat-tool-tag{
  background:rgba(91,91,214,.04);border:1px solid rgba(91,91,214,.08);
  border-radius:18px;padding:4px 12px;
  font-size:10px;font-weight:500;color:var(--txt-dim);
}
.feat-tool-more{
  background:rgba(91,91,214,.08);border:1px solid rgba(91,91,214,.15);
  border-radius:18px;padding:4px 12px;
  font-size:10px;font-weight:600;color:var(--accent1);
  cursor:pointer;
}
/* experience timeline */
.exp-timeline{display:flex;flex-direction:column;gap:16px}
.tl-item{display:flex;gap:10px}
.tl-dot{width:7px;height:7px;border-radius:50%;background:var(--c,var(--accent1));flex-shrink:0;margin-top:4px;box-shadow:0 0 7px var(--c,var(--accent1))}
.tl-body{flex:1}
.tl-period{font-size:8.5px;font-weight:500;color:var(--muted);margin-bottom:2px}
.tl-role{font-size:11.5px;font-weight:700;color:var(--txt);margin-bottom:1px}
.tl-company{font-size:9.5px;color:var(--txt-dim);margin-bottom:4px;display:block}
.tl-bullets{list-style:none;display:flex;flex-direction:column;gap:2px}
.tl-bullets li{font-size:9.5px;color:var(--txt-dim);padding-left:9px;position:relative}
.tl-bullets li::before{content:'·';position:absolute;left:0;color:var(--muted)}

/* ══ 4 · STATS ══ */
.card-stat-main{
  background:var(--card);border-color:var(--border);
  cursor:pointer;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:22px 28px;
}
.stat-eyebrow{
  font-size:9px;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.1em;
  margin-bottom:4px;
}
.stat-rows{display:flex;flex-direction:column;gap:0;flex:1;justify-content:space-evenly}
.stat-row{display:flex;align-items:center;gap:18px;padding:10px 0}
.stat-sep{width:100%;height:1px;background:var(--border)}
.stat-figure{
  font-size:54px;font-weight:900;line-height:1;
  letter-spacing:-3px;color:var(--accent1);
  flex-shrink:0;min-width:110px;
}
.stat-sup{font-size:24px;font-weight:700;letter-spacing:0;vertical-align:super}
.stat-desc{display:flex;flex-direction:column;gap:2px}
.stat-desc strong{font-size:13px;font-weight:700;color:var(--txt);line-height:1.2}
.stat-desc span{font-size:11px;font-weight:400;color:var(--txt-dim)}

/* ══ 5 · COMPANIES ══ */
.card-companies{
  background:var(--card);border-color:var(--border);
  display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  padding:16px 18px;gap:8px;cursor:pointer;
}
.co-label{font-size:14px;font-weight:700;color:var(--txt)}
.co-sublabel{font-size:10px;font-weight:500;color:var(--muted);letter-spacing:.03em}
/* logo grid */
.co-logos{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.co-logo-item{
  width:44px;height:44px;border-radius:11px;
  background:var(--card-alt);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;flex-shrink:0;
  transition:background .2s,transform .2s var(--spring),border-color .2s;
  text-decoration:none;
}
.co-logo-item:hover{background:rgba(91,91,214,.06);border-color:rgba(91,91,214,.15);transform:scale(1.1)}
.co-logo-item img{width:28px;height:28px;object-fit:contain}
.co-logo-fb{
  width:28px;height:28px;
  display:none;align-items:center;justify-content:center;
  font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.04em;
}
.co-logo-item-accent{border-color:rgba(91,91,214,.2);background:rgba(91,91,214,.05)}
.co-logo-item-accent .co-logo-fb{color:var(--accent1);display:flex}

/* ══ 6 · MAP — 3D Globe ══ */
.card-globe{
  background:transparent!important;
  border:none!important;
  box-shadow:none!important;
  overflow:visible!important;
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
#globeCanvas{
  width:100%;height:100%;
  display:block;
}
.map-tag{
  position:absolute;top:10px;left:12px;z-index:4;
  font-size:8px;font-weight:700;color:var(--txt-dim);
  letter-spacing:.1em;text-transform:uppercase;
  display:flex;flex-direction:column;gap:2px;
}
.map-tag-sub{font-size:7px;font-weight:500;color:var(--muted);letter-spacing:.04em;text-transform:none}

/* ══ 7 · RANKING ══ */
.card-ranking{
  background:var(--card);border-color:var(--border);
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  padding:16px 12px;cursor:pointer;gap:6px;
}
.rank-eyebrow{font-size:8px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.09em;text-align:center}
.ranking-split{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;justify-content:center;width:100%}
.rank-item{display:flex;flex-direction:column;align-items:center;padding:10px 0;width:100%}
.rank-num{font-size:36px;font-weight:900;line-height:1;letter-spacing:-2px;color:var(--txt)}
.rank-lbl{font-size:9px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:2px;text-align:center}
.rank-divider{width:40px;height:1px;background:var(--border)}
.rank-school{
  font-size:8.5px;font-weight:600;color:var(--muted);text-align:center;
  letter-spacing:.02em;display:flex;align-items:center;justify-content:center;gap:4px;
  padding-top:6px;border-top:1px solid var(--border);width:100%;
}

/* ══ PAGE 2 ══ */
#page2{background:var(--bg)}
.page2-inner{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.page2-content{display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center;max-width:400px}
.page2-badge{background:rgba(91,91,214,.1);border:1px solid rgba(91,91,214,.2);border-radius:20px;padding:5px 16px;font-size:11px;font-weight:600;color:var(--accent1);letter-spacing:.06em}
.page2-title{font-size:54px;font-weight:900;color:var(--txt);letter-spacing:-3px;line-height:.95}
.page2-sub{font-size:13px;color:var(--muted);font-weight:400;line-height:1.6}
.btn-back{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border-md);border-radius:30px;padding:10px 22px;font-size:13px;font-weight:600;color:var(--txt);cursor:pointer;font-family:var(--font);box-shadow:var(--sh-card);transition:box-shadow .2s,transform .2s var(--spring)}
.btn-back:hover{box-shadow:var(--sh-hover);transform:translateX(-3px)}

/* ══ MODALS ══ */
.modal-overlay{
  position:fixed;inset:0;z-index:100;
  background:rgba(0,0,0,.35);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s ease;
}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{
  background:#fff;border:1px solid var(--border);
  border-radius:22px;padding:38px 42px;
  max-width:560px;width:92%;max-height:82vh;overflow-y:auto;
  position:relative;
  box-shadow:0 24px 64px rgba(0,0,0,.14);
}
.modal-sm{max-width:440px}
.modal-box::-webkit-scrollbar{width:3px}
.modal-box::-webkit-scrollbar-thumb{background:rgba(0,0,0,.1);border-radius:3px}
.modal-close{
  position:absolute;top:14px;right:16px;
  background:var(--card-alt);border:1px solid var(--border);
  border-radius:50%;width:30px;height:30px;cursor:pointer;
  color:var(--txt-dim);display:flex;align-items:center;justify-content:center;
  transition:background .2s,color .2s;
}
.modal-close:hover{background:var(--border-md);color:var(--txt)}
.modal-title{font-size:26px;font-weight:800;color:var(--txt);margin-bottom:4px;letter-spacing:-.8px}
.modal-sub{font-size:11.5px;color:var(--muted);margin-bottom:22px}

/* Work modal */
.exp-list{display:flex;flex-direction:column;gap:22px;margin-top:16px}
.exp-item{display:flex;gap:12px}
.exp-dot{width:9px;height:9px;flex-shrink:0;border-radius:50%;background:var(--c);margin-top:5px;box-shadow:0 0 8px var(--c)}
.exp-body{flex:1}
.exp-period{font-size:9.5px;font-weight:500;color:var(--muted);letter-spacing:.04em}
.exp-body h3{font-size:14px;font-weight:700;color:var(--txt);margin:3px 0 2px}
.exp-co{font-size:11px;color:var(--txt-dim);margin-bottom:7px;display:block}
.exp-body ul{list-style:none;display:flex;flex-direction:column;gap:3px}
.exp-body li{font-size:11.5px;color:var(--txt-dim);padding-left:11px;position:relative}
.exp-body li::before{content:'·';position:absolute;left:0;color:var(--muted)}

/* Skills modal */
.skills-section{margin-bottom:24px}
.skills-section:last-child{margin-bottom:0}
.section-label{font-size:9.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:11px}
.highlights-row{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}
.hl-chip{background:var(--card-alt);border:1px solid var(--border);border-radius:11px;padding:9px 7px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:3px}
.hl-num{font-size:18px;font-weight:900;color:var(--txt);display:flex;align-items:center;justify-content:center}
.hl-txt{font-size:8px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.hl-accent{border-color:rgba(217,119,6,.2);background:rgba(217,119,6,.05)}
.lang-grid{display:flex;flex-direction:column;gap:10px}
.lang-row{display:flex;align-items:center;gap:10px}
.lang-flag{width:22px;height:15px;object-fit:cover;border-radius:2px;flex-shrink:0}
.lang-name{font-size:11.5px;font-weight:600;color:var(--txt);width:54px;flex-shrink:0}
.lang-bar{flex:1;height:2.5px;background:var(--card-alt);border-radius:3px;overflow:hidden}
.lang-fill{height:100%;width:var(--w);background:var(--c,var(--accent1));border-radius:3px;transition:width 1s ease}
.lang-lvl{font-size:9.5px;font-weight:600;color:var(--muted);width:36px;text-align:right;flex-shrink:0}
.tool-grid{display:flex;flex-wrap:wrap;gap:6px}
.tool-chip{background:var(--card-alt);border:1px solid var(--border);border-radius:16px;padding:5px 12px;font-size:11.5px;font-weight:500;color:var(--txt-dim);cursor:default;transition:background .2s}
.tool-chip:hover{background:rgba(91,91,214,.08);border-color:rgba(91,91,214,.2)}
.soft-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.soft-tag{display:flex;align-items:center;gap:8px;background:var(--card-alt);border:1px solid var(--border);border-radius:9px;padding:8px 12px;font-size:11.5px;font-weight:500;color:var(--txt-dim)}
.soft-dot{width:6px;height:6px;border-radius:50%;background:var(--c);flex-shrink:0}

/* Projects modal */
.proj-grid{display:flex;flex-direction:column;gap:9px}
.proj-card{display:flex;align-items:center;gap:12px;background:var(--card-alt);border:1px solid var(--border);border-radius:13px;padding:12px 14px;transition:background .2s,border-color .2s}
.proj-card:hover{background:#eee;border-color:var(--border-md)}
.proj-locked{opacity:.4;pointer-events:none}
.proj-icon{width:44px;height:44px;border-radius:11px;flex-shrink:0;background:var(--bg,#ddd);display:flex;align-items:center;justify-content:center}
.proj-info{flex:1}
.proj-info h3{font-size:13.5px;font-weight:700;color:var(--txt);margin-bottom:2px}
.proj-info p{font-size:10.5px;color:var(--muted)}
.proj-btn{flex-shrink:0;padding:5px 13px;border-radius:16px;font-size:10.5px;font-weight:600;background:var(--card);color:var(--txt);border:1px solid var(--border-md);text-decoration:none;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:4px;font-family:var(--font)}
.proj-btn:hover{background:rgba(91,91,214,.08)}
.proj-soon{background:rgba(91,91,214,.08);border-color:rgba(91,91,214,.2);color:var(--accent1);cursor:default}
.proj-wip{background:var(--card-alt);border-color:var(--border);color:var(--muted);cursor:default}

/* Contact modal */
.contact-list{display:flex;flex-direction:column;gap:7px}
.contact-row{display:flex;align-items:center;gap:11px;background:var(--card-alt);border:1px solid var(--border);border-radius:12px;padding:11px 13px;text-decoration:none;cursor:pointer;transition:background .2s,border-color .2s}
.contact-row:hover{background:#eee;border-color:var(--border-md)}
.c-icon{width:36px;height:36px;border-radius:9px;flex-shrink:0;background:var(--bg,rgba(0,0,0,.04));border:1px solid var(--bc,var(--border));display:flex;align-items:center;justify-content:center}
.c-info{flex:1;display:flex;flex-direction:column;gap:1px}
.c-label{font-size:8.5px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.c-value{font-size:12.5px;font-weight:600;color:var(--txt)}
.c-arrow{color:var(--muted);flex-shrink:0}
.contact-locations{display:flex;gap:8px;margin-top:6px}
.c-loc{flex:1;display:flex;align-items:flex-start;gap:8px;background:var(--card-alt);border:1px solid var(--border);border-radius:11px;padding:11px 13px}
.c-loc div{display:flex;flex-direction:column;gap:1px}
.c-loc-city{font-size:11.5px;font-weight:600;color:var(--txt)}
.c-loc-flag{font-size:10px}
.c-loc-status{font-size:8.5px;font-weight:500;color:var(--muted)}

/* ══ RESPONSIVE ══ */
@media(max-width:1200px){
  .bento-grid{
    grid-template-columns:240px 1fr 200px 180px;
    grid-template-rows:88px 1fr 1fr 220px;
  }
  .card-heading   {grid-column:2/5}
  .card-ranking   {display:none}
  .card-stat-main {grid-column:3/5}
  .card-map       {grid-column:3/5}
}
@media(max-width:960px){
  body{padding:14px}
  .page{position:relative;padding:14px;min-height:100vh;height:auto;align-items:flex-start}
  .page-wrapper{flex-direction:column;min-height:auto}
  .sidebar{display:none}
  .bento-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;gap:12px}
  .card-profile{grid-column:1/3;min-height:auto;grid-row:auto;padding:20px 18px 20px}
  .card-heading{grid-column:1/3;overflow:visible;grid-row:auto}
  .card-featured{grid-column:1/3;min-height:auto;grid-row:auto}
  .card-stat-main{grid-column:1/3;grid-row:auto;min-height:auto}
  .stat-figure{font-size:40px;min-width:88px}
  .card-ranking{display:flex;grid-column:1/3;grid-row:auto;flex-direction:row;gap:16px;padding:16px 20px}
  .ranking-split{flex-direction:row;gap:16px}
  .rank-item{padding:0}
  .rank-divider{width:1px;height:40px}
  .card-companies,.card-map{grid-column:auto}
  .main-title{font-size:48px;letter-spacing:-3px}
  .sp-highlights{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .page{position:relative;padding:10px;min-height:100vh;height:auto;align-items:flex-start;overflow-y:auto}
  .page-wrapper{flex-direction:column;min-height:auto;align-items:stretch}
  .bento-grid{grid-template-columns:1fr;gap:10px}
  .card-profile,.card-heading,.card-featured,.card-stat-main,
  .card-companies,.card-map,.card-ranking{grid-column:1;grid-row:auto}
  .card-profile{order:1}
  .card-heading{order:2}
  .card-ranking{order:3}
  .card-featured{order:5}
  .card-stat-main{order:6}
  .card-companies{order:4}
  .card-map{order:7}

  /* ── Profile card: stack vertically, no absolute ── */
  .card-profile{
    position:relative;padding:24px 18px 20px;min-height:auto;
    display:flex;flex-direction:column;align-items:center;
    justify-content:flex-start;gap:14px;
  }
  .profile-ring{display:none}
  .ring-outer{display:none}
  .photo-wrap{
    position:relative;top:auto;left:auto;transform:none;
    width:110px;height:110px;flex-shrink:0;
  }
  .profile-info{text-align:center;width:100%}
  .greeting{text-align:center}
  .pname{font-size:28px;letter-spacing:-1.5px;text-align:center;line-height:1}
  .pemail{justify-content:center}
  .badge-wrap{position:relative;bottom:auto;right:auto;align-self:center}
  .badge-circle{width:52px;height:52px}
  .badge-svg{width:46px;height:46px}
  .badge-text{font-size:6px}
  .profile-actions{justify-content:center}
  .btn-linkedin{flex:unset}
  .btn-slide{width:36px;height:36px}

  /* ── Heading ── */
  .main-title{font-size:36px;letter-spacing:-2px}
  .main-sub{font-size:10px}
  .card-heading{padding:6px 4px 4px}

  /* ── Featured card: tighter ── */
  .feat-header{padding:10px 12px 0}
  .feat-big-stats{padding:8px 12px 0;gap:6px}
  .feat-big-stat{padding:10px 4px}
  .feat-big-num{font-size:20px}
  .feat-big-lbl{font-size:7px}
  .feat-langs-row{padding:8px 12px 0;gap:5px}
  .feat-lang{padding:7px 4px;gap:3px}
  .feat-lang-flag{width:18px;height:12px}
  .feat-lang-lvl{font-size:8px}
  .feat-tools-row{padding:8px 12px 12px;gap:4px}
  .feat-tool-tag{padding:3px 9px;font-size:9px}
  .feat-tool-more{padding:3px 9px;font-size:9px}
  .feat-cta-btn{padding:4px 10px;font-size:9px}
  .feat-badge{padding:3px 9px;font-size:9px}

  /* ── Ranking card: horizontal, clean ── */
  .card-ranking{
    display:flex;flex-direction:row;align-items:center;
    padding:14px 16px;gap:12px;
  }
  .rank-eyebrow{font-size:7px;text-align:left;white-space:nowrap}
  .ranking-split{flex-direction:row;gap:12px;flex:1}
  .rank-item{padding:0;align-items:center}
  .rank-num{font-size:24px;letter-spacing:-1px}
  .rank-lbl{font-size:7px;margin-top:1px}
  .rank-divider{width:1px;height:28px}
  .rank-school{font-size:7px;padding-top:0;border-top:none;white-space:nowrap}

  /* ── Stats ── */
  .card-stat-main{padding:16px 18px}
  .stat-row{flex-direction:column;align-items:flex-start;gap:4px;padding:8px 0}
  .stat-figure{font-size:36px;min-width:auto}
  .stat-desc strong{font-size:12px}
  .stat-desc span{font-size:10px}

  /* ── Companies ── */
  .card-companies{padding:14px 14px;gap:6px}
  .co-label{font-size:13px}
  .co-sublabel{font-size:9px}
  .co-logo-item{width:40px;height:40px;border-radius:10px}
  .co-logo-item img{width:26px;height:26px}

  /* ── Globe ── */
  .card-globe{min-height:200px}
  .map-tag{font-size:7px}
  .map-tag-sub{font-size:6.5px}

  /* ── Card peek: visible on mobile via JS ── */
  .card-peek{transition:max-height .4s ease, opacity .3s ease, margin .3s ease}
  .card.in-view .card-peek{max-height:60px;opacity:1;margin-top:8px}

  /* ── Modal fixes for mobile ── */
  .modal-box{padding:24px 20px;width:96%;max-height:88vh;border-radius:18px}
  .modal-title{font-size:22px}
  .soft-grid{grid-template-columns:1fr}
  .contact-locations{flex-direction:column}
  .highlights-row{grid-template-columns:repeat(2,1fr)}
  .exp-body h3{font-size:13px}
  .exp-period{font-size:9px}
  .exp-body li{font-size:10.5px}
}
