/* =========================================================
   Wilson Kouassi — Portfolio · CALM GLASS / macOS window
   Soft periwinkle · neutral frosted panels · one blue accent
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Manrope:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
  --radius: 26px; --radius-sm: 16px; --maxw: 1380px; --bar: 62px;
  --ease: cubic-bezier(.22,1,.36,1); --spring: cubic-bezier(.34,1.4,.64,1);
  --font-display: 'Bricolage Grotesque', sans-serif;
  --font-body: 'Manrope', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --blur: 32px;
}

html[data-theme="light"] {
  --desk: radial-gradient(110% 90% at 8% 0%, #d6e0ff 0%, transparent 55%), radial-gradient(90% 90% at 100% 12%, #e7d8ff 0%, transparent 50%), radial-gradient(120% 110% at 60% 100%, #cfe5ff 0%, transparent 55%), linear-gradient(135deg,#c4d2f6 0%,#c6bef0 45%,#d2def8 100%);
  --text: #232540; --muted: #5f648a; --faint: #989ec0;
  --glass: rgba(255,255,255,.42); --glass-2: rgba(255,255,255,.66); --glass-3: rgba(255,255,255,.86);
  --brd: rgba(255,255,255,.9); --brd-soft: rgba(90,100,150,.16); --hi: rgba(255,255,255,1);
  --gloss: rgba(255,255,255,.65); --rim: rgba(255,255,255,.55); --deep: rgba(60,70,130,.16);
  --shadow: 0 30px 70px -26px rgba(50,55,110,.5);
  --accent: #2f6bff; --accent-2: #5b8cff; --accent-soft: rgba(47,107,255,.14);
  --tint-a: rgba(120,150,255,.22); --tint-b: rgba(170,140,255,.22);
  --grain: .02; --au1: #9fb4ff; --au2: #c0a8ff; --au3: #8fd4ff; --au-op: .55;
}
html[data-theme="dark"] {
  --desk: radial-gradient(110% 90% at 10% 0%, #1d2950 0%, transparent 55%), radial-gradient(90% 90% at 100% 10%, #2a1f55 0%, transparent 50%), radial-gradient(120% 120% at 65% 100%, #122a52 0%, transparent 55%), radial-gradient(120% 120% at 20% 30%,#10162e 0%,#0a0d1e 60%,#070912 100%);
  --text: #eef2ff; --muted: #a3abcf; --faint: #686f95;
  --glass: rgba(255,255,255,.05); --glass-2: rgba(255,255,255,.085); --glass-3: rgba(255,255,255,.12);
  --brd: rgba(255,255,255,.16); --brd-soft: rgba(255,255,255,.09); --hi: rgba(255,255,255,.4);
  --gloss: rgba(255,255,255,.13); --rim: rgba(255,255,255,.08); --deep: rgba(0,0,0,.55);
  --shadow: 0 30px 70px -26px rgba(0,0,0,.75);
  --accent: #6f9bff; --accent-2: #8fb2ff; --accent-soft: rgba(111,155,255,.2);
  --tint-a: rgba(95,125,235,.26); --tint-b: rgba(150,115,245,.24);
  --grain: .045; --au1: #2c3c78; --au2: #3c2f74; --au3: #1b3a68; --au-op: .6;
}

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: hidden; }
body { font-family: var(--font-body); background: var(--desk); background-attachment: fixed; color: var(--text); line-height: 1.6; font-size: 16px; -webkit-font-smoothing: antialiased; min-height: 100vh; transition: color .5s var(--ease); }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
::selection { background: var(--accent); color: #fff; }

/* vivid aurora behind the glass */
.aurora { position: fixed; inset: -10%; z-index: 0; overflow: hidden; pointer-events: none; }
.aurora span { position: absolute; border-radius: 50%; filter: blur(80px); opacity: var(--au-op); }
.aurora .b1 { width: 48vw; height: 48vw; background: var(--au1); top: -12%; left: -8%; animation: drift1 26s var(--ease) infinite alternate; }
.aurora .b2 { width: 42vw; height: 42vw; background: var(--au2); bottom: -14%; right: -8%; animation: drift2 30s var(--ease) infinite alternate; }
.aurora .b3 { width: 34vw; height: 34vw; background: var(--au3); top: 30%; left: 40%; animation: drift3 34s var(--ease) infinite alternate; }
@keyframes drift1 { to { transform: translate(12vw,9vh) scale(1.18); } }
@keyframes drift2 { to { transform: translate(-10vw,-8vh) scale(1.14); } }
@keyframes drift3 { to { transform: translate(-8vw,7vh) scale(1.2); } }
body::after { content: ""; position: fixed; inset: 0; z-index: 1; pointer-events: none; opacity: var(--grain); background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* cursor */
.cur { position: fixed; top: 0; left: 0; z-index: 10000; pointer-events: none; transform: translate(-50%,-50%); border-radius: 50%; }
.cur-dot { width: 7px; height: 7px; background: var(--accent); }
.cur-ring { width: 38px; height: 38px; border: 1.5px solid var(--accent); opacity: .5; transition: width .3s var(--spring), height .3s var(--spring), opacity .3s; }
.cur-ring.hover { width: 60px; height: 60px; opacity: .9; }
@media (hover: none), (max-width: 760px) { .cur { display: none !important; } }

/* ===== LIQUID GLASS primitive ===== */
.glass {
  position: relative;
  background: linear-gradient(155deg, var(--gloss) 0%, transparent 34%, transparent 70%, var(--deep) 130%), var(--glass);
  -webkit-backdrop-filter: blur(var(--blur)) saturate(190%) brightness(1.05);
  backdrop-filter: blur(var(--blur)) saturate(190%) brightness(1.05);
  border: 1px solid var(--brd);
  box-shadow:
    var(--shadow),
    inset 0 1.5px 0 var(--hi),
    inset 1px 0 0 var(--rim),
    inset -1px 0 0 var(--rim),
    inset 0 -22px 38px -28px var(--deep);
}
/* crisp specular streak across the top — the “wet” look */
.glass.sheen::before {
  content: ""; position: absolute; left: 0; right: 0; top: 0; height: 45%; border-radius: inherit; pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,.16), transparent);
  -webkit-mask-image: radial-gradient(120% 100% at 50% -20%, #000 30%, transparent 65%);
  mask-image: radial-gradient(120% 100% at 50% -20%, #000 30%, transparent 65%);
  opacity: .9;
}
.glass.sheen::after { content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none; opacity: 0; background: radial-gradient(420px circle at var(--mx,50%) var(--my,50%), color-mix(in oklab,var(--accent) 22%, transparent), transparent 62%); transition: opacity .45s; mix-blend-mode: screen; }
.glass.sheen:hover::after { opacity: 1; }

/* ============ WINDOW SHELL ============ */
.desktop { position: relative; z-index: 2; min-height: 100vh; padding: 0; }
.window { max-width: none; margin: 0; }
.winbar { position: sticky; top: 0; z-index: 60; display: flex; align-items: center; gap: 16px; padding: 12px clamp(16px,2.4vw,30px); border-radius: 0; background: var(--glass-2); -webkit-backdrop-filter: blur(30px) saturate(160%); backdrop-filter: blur(30px) saturate(160%); border-bottom: 1px solid var(--brd-soft); box-shadow: inset 0 1px 0 var(--hi); }
.lights { display: flex; gap: 8px; padding-right: 6px; }
.lights i { width: 12px; height: 12px; border-radius: 50%; display: block; }
.lights .r { background: #ff5f57; } .lights .y { background: #febc2e; } .lights .g { background: #28c840; }
.win-tabs { display: flex; gap: 3px; margin: 0 auto; }
.win-tabs a { position: relative; padding: 8px 16px; border-radius: 100px; font-size: 14px; font-weight: 600; color: var(--muted); transition: color .25s, background .25s; white-space: nowrap; }
.win-tabs a:hover { color: var(--text); }
.win-tabs a.active { color: var(--accent); }
.win-tabs a.active::after { content: ""; position: absolute; left: 16px; right: 16px; bottom: -13px; height: 2px; background: var(--accent); border-radius: 2px; }
.win-tools { display: flex; align-items: center; gap: 8px; }
.icon-btn { width: 38px; height: 38px; border-radius: 11px; background: var(--glass-2); border: 1px solid var(--brd); display: grid; place-items: center; color: var(--text); transition: transform .35s var(--spring), border-color .25s, color .25s; box-shadow: inset 0 1px 0 var(--hi); }
.icon-btn:hover { transform: translateY(-2px); border-color: var(--accent); color: var(--accent); }
.icon-btn svg { width: 18px; height: 18px; }
.lang-btn { width: auto; padding: 0 12px; display: flex; flex-direction: row; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 12px; font-weight: 600; gap: 4px; white-space: nowrap; }
.lang-btn .on { color: var(--accent); } .lang-btn .off { color: var(--faint); }
.theme-btn .sun { display: none; }
html[data-theme="light"] .theme-btn .sun { display: block; } html[data-theme="light"] .theme-btn .moon { display: none; }
.avatar-chip { width: 38px; height: 38px; border-radius: 11px; overflow: hidden; border: 1px solid var(--brd); flex-shrink: 0; }
.avatar-chip img { width: 100%; height: 100%; object-fit: cover; }
.burger { display: none; }

.winbody { display: grid; grid-template-columns: 260px minmax(0,1fr); background: var(--glass); -webkit-backdrop-filter: blur(26px) saturate(150%); backdrop-filter: blur(26px) saturate(150%); min-height: calc(100vh - var(--bar)); }
.sidebar { padding: 26px 18px; border-right: 1px solid var(--brd-soft); position: sticky; top: var(--bar); align-self: start; max-height: calc(100vh - var(--bar)); overflow-y: auto; }
.sidebar::-webkit-scrollbar { width: 0; }
.side-group + .side-group { margin-top: 26px; }
.side-group h4 { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--faint); margin: 0 10px 10px; }
.side-profile { display: flex; align-items: center; gap: 11px; padding: 10px; border-radius: 14px; background: var(--glass-2); border: 1px solid var(--brd-soft); margin-bottom: 22px; }
.side-profile img { width: 40px; height: 40px; border-radius: 11px; object-fit: cover; flex-shrink: 0; }
.side-profile > div { min-width: 0; }
.side-profile .sp-name { font-family: var(--font-display); font-weight: 700; font-size: 14px; line-height: 1.2; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.side-profile .sp-role { font-family: var(--font-mono); font-size: 11px; color: var(--accent); white-space: nowrap; }
.cat-list { list-style: none; display: flex; flex-direction: column; gap: 2px; }
.cat-list li a, .cat-list li button { display: flex; align-items: center; gap: 11px; width: 100%; padding: 10px 12px; border-radius: 11px; font-weight: 600; font-size: 14px; color: var(--muted); transition: background .2s, color .2s; text-align: left; }
.cat-list li a:hover, .cat-list li button:hover, .cat-list li a.active, .cat-list li button.active { background: var(--glass-2); color: var(--text); }
.cat-list li a.active, .cat-list li button.active { box-shadow: inset 0 0 0 1px var(--brd-soft); }
.cat-list .dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.cat-list .ic { width: 17px; height: 17px; color: currentColor; flex-shrink: 0; }
.cat-list .c { margin-left: auto; font-family: var(--font-mono); font-size: 11.5px; color: var(--faint); }
.content { padding: clamp(22px,3vw,44px); min-width: 0; }

/* content header (tabs row like reference) */
.content-head { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-bottom: 26px; }
.content-head .ch-title { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.4rem,2.4vw,1.9rem); }
.subtabs { display: flex; gap: 4px; }
.subtabs button { padding: 8px 16px; border-radius: 100px; font-size: 13.5px; font-weight: 600; color: var(--muted); transition: .2s; }
.subtabs button:hover { color: var(--text); }
.subtabs button.active { color: var(--accent); background: var(--accent-soft); }

/* mobile menu */
.mobile-panel { position: fixed; inset: 12px; z-index: 99; border-radius: 26px; display: flex; flex-direction: column; justify-content: center; gap: 4px; padding: 36px; transform: scale(.95); opacity: 0; visibility: hidden; transition: transform .45s var(--spring), opacity .35s, visibility .35s; }
.mobile-panel.open { transform: scale(1); opacity: 1; visibility: visible; }
.mobile-panel a { font-family: var(--font-display); font-size: clamp(1.7rem,8vw,2.6rem); font-weight: 700; padding: 10px 0; color: var(--text); border-bottom: 1px solid var(--brd-soft); }
.mobile-panel a .idx { font-family: var(--font-mono); font-size: 12px; color: var(--accent); vertical-align: super; margin-right: 12px; }

/* ---------- Type ---------- */
h1,h2,h3,h4 { font-family: var(--font-display); font-weight: 700; line-height: 1.04; letter-spacing: -.02em; }
.h-xl { font-size: clamp(2rem,4.4vw,3.4rem); } .h-lg { font-size: clamp(1.6rem,3vw,2.3rem); }
.lead { font-size: clamp(1rem,1.4vw,1.18rem); color: var(--muted); max-width: 62ch; text-wrap: pretty; }
.muted { color: var(--muted); } .accent { color: var(--accent); }
.mono-label { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .04em; text-transform: uppercase; color: var(--accent); display: inline-flex; align-items: center; gap: 8px; }

/* ---------- Buttons ---------- */
.btn { display: inline-flex; align-items: center; gap: 9px; padding: 12px 22px; border-radius: 100px; font-weight: 700; font-size: 14px; transition: transform .35s var(--spring), background .25s, box-shadow .25s, border-color .25s; }
.btn svg { width: 16px; height: 16px; }
.btn-primary { background: var(--accent); color: #fff; box-shadow: 0 8px 22px -8px var(--accent), inset 0 1px 0 rgba(255,255,255,.35); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 28px -8px var(--accent), inset 0 1px 0 rgba(255,255,255,.45); }
.btn-glass { background: var(--glass-2); border: 1px solid var(--brd); color: var(--text); box-shadow: inset 0 1px 0 var(--hi); }
.btn-glass:hover { transform: translateY(-2px); border-color: var(--accent); color: var(--accent); }
.btn-sm { padding: 9px 18px; font-size: 13px; }
.btn-block { width: 100%; justify-content: center; }

/* ---------- Banner (hero card) ---------- */
.banner { position: relative; overflow: hidden; border-radius: var(--radius); padding: clamp(28px,4vw,48px); background: linear-gradient(120deg, var(--tint-a), var(--tint-b)); -webkit-backdrop-filter: blur(var(--blur)) saturate(180%); backdrop-filter: blur(var(--blur)) saturate(180%); border: 1px solid var(--brd); box-shadow: var(--shadow), inset 0 1.5px 0 var(--hi), inset 0 -22px 40px -28px var(--deep); margin-bottom: 26px; }
.banner::before { content: ""; position: absolute; left: 0; right: 0; top: 0; height: 50%; pointer-events: none; background: linear-gradient(180deg, rgba(255,255,255,.18), transparent); -webkit-mask-image: radial-gradient(130% 100% at 30% -20%, #000 30%, transparent 68%); mask-image: radial-gradient(130% 100% at 30% -20%, #000 30%, transparent 68%); }
.banner .b-inner { position: relative; z-index: 2; max-width: 62%; }
.banner h1 { font-size: clamp(1.9rem,4vw,3.2rem); font-weight: 800; letter-spacing: -.03em; margin: 14px 0 16px; line-height: 1; }
.banner .pill { margin-bottom: 4px; }
.banner .b-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
/* hero with photo */
.banner-hero { display: grid; grid-template-columns: minmax(0,1.2fr) minmax(0,.8fr); gap: clamp(24px,3vw,44px); align-items: center; }
.banner-hero .b-inner { max-width: 100%; }
.banner-hero .b-photo { position: relative; z-index: 2; justify-self: end; width: 100%; max-width: 340px; aspect-ratio: 4/5; }
.banner-hero .b-photo img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius); border: 1px solid var(--brd); box-shadow: 0 20px 50px -18px rgba(40,40,90,.45); }
.banner-hero .b-photo-badge { position: absolute; bottom: 14px; left: 14px; display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; border-radius: 100px; font-family: var(--font-mono); font-size: 12px; font-weight: 600; background: var(--glass-3); -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px); border: 1px solid var(--brd); box-shadow: inset 0 1px 0 var(--hi); }
.banner .orb { position: absolute; right: -40px; top: 50%; transform: translateY(-50%); width: 360px; height: 360px; border-radius: 50%; background: radial-gradient(circle at 35% 30%, #fff7, transparent 45%), radial-gradient(circle at 65% 70%, var(--accent), var(--accent-2) 60%, transparent 75%); filter: blur(2px); opacity: .85; pointer-events: none; animation: float 8s var(--ease) infinite alternate; }
.banner .orb.small { width: 120px; height: 120px; right: 280px; top: 22%; background: radial-gradient(circle at 40% 35%, #fff8, transparent 50%), radial-gradient(circle, var(--au2), transparent 70%); animation-duration: 6s; }
@keyframes float { to { transform: translateY(-58%) translateX(-14px); } }

.pill { display: inline-flex; align-items: center; gap: 8px; padding: 7px 14px; border-radius: 100px; font-size: 12px; font-weight: 600; font-family: var(--font-mono); background: var(--glass-2); border: 1px solid var(--brd-soft); }
.status-dot { width: 7px; height: 7px; border-radius: 50%; background: #28c840; box-shadow: 0 0 0 0 rgba(40,200,64,.5); animation: pulse 2s infinite; }
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(40,200,64,.5);} 70%{box-shadow:0 0 0 8px rgba(40,200,64,0);} 100%{box-shadow:0 0 0 0 rgba(40,200,64,0);} }

/* ---------- Section label ---------- */
.sec-label { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin: 34px 0 16px; flex-wrap: wrap; }
.sec-label h2 { font-size: clamp(1.1rem,1.8vw,1.4rem); font-weight: 700; }
.sec-label .more { font-family: var(--font-mono); font-size: 12.5px; color: var(--accent); font-weight: 600; }

/* ---------- List rows (installed style) ---------- */
.rows { display: flex; flex-direction: column; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--brd); background: var(--glass-2); }
.row { display: grid; grid-template-columns: auto minmax(0,1fr) auto auto; gap: 18px; align-items: center; padding: 18px 22px; cursor: pointer; transition: background .25s; }
.row + .row { border-top: 1px solid var(--brd-soft); }
.row:hover { background: var(--glass-3); }
.row .r-ico { width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center; font-family: var(--font-display); font-weight: 800; font-size: 15px; color: #fff; flex-shrink: 0; box-shadow: inset 0 1px 0 rgba(255,255,255,.35); }
.row .r-name { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; }
.r-sub { font-size: 13px; color: var(--muted); margin-top: 2px; overflow: hidden; text-overflow: ellipsis; }
.row .r-status { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--muted); font-family: var(--font-mono); }
.row .r-status .s-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }
.row .r-status.ok .s-dot { background: #28c840; }
@media (max-width: 620px) { .row { grid-template-columns: auto minmax(0,1fr); } .row .r-status { display: none; } }

/* ---------- Cards grid ---------- */
.cards { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 18px; perspective: 1200px; }
.card { padding: 26px; border-radius: var(--radius); cursor: pointer; transition: transform .5s var(--ease), box-shadow .5s var(--ease); will-change: transform; }
.card:hover { transform: translateY(-7px) scale(1.012); box-shadow: var(--shadow), 0 30px 60px -22px var(--accent-soft), inset 0 1.5px 0 var(--hi), inset 1px 0 0 var(--rim), inset -1px 0 0 var(--rim); }
.card .c-top { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.card .c-ico { width: 44px; height: 44px; border-radius: 13px; display: grid; place-items: center; font-family: var(--font-display); font-weight: 800; color: #fff; font-size: 14px; box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 6px 16px -6px rgba(0,0,0,.3); }
.card .c-idx { font-family: var(--font-mono); font-size: 12px; color: var(--faint); }
.card h3 { font-size: 1.25rem; margin: 18px 0 9px; }
.card .c-desc { color: var(--muted); font-size: 14px; line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 18px; }
.tag { font-family: var(--font-mono); font-size: 11px; padding: 4px 11px; border-radius: 100px; background: var(--glass-2); border: 1px solid var(--brd-soft); color: var(--muted); white-space: nowrap; box-shadow: inset 0 1px 0 var(--hi); }
.tag.role { color: var(--accent); border-color: color-mix(in oklab,var(--accent) 35%,transparent); }
.c-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--brd-soft); }
.c-open { font-family: var(--font-mono); font-size: 12.5px; font-weight: 600; color: var(--accent); display: inline-flex; align-items: center; gap: 6px; }
.c-open svg { width: 14px; height: 14px; transition: transform .35s var(--spring); }
.card:hover .c-open svg { transform: translate(3px,-3px); }

/* ---------- Modal ---------- */
.modal-back { position: fixed; inset: 0; z-index: 200; background: rgba(20,24,45,.4); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); display: flex; justify-content: center; align-items: flex-start; padding: 6vh 20px; overflow-y: auto; opacity: 0; visibility: hidden; transition: opacity .35s, visibility .35s; }
.modal-back.open { opacity: 1; visibility: visible; }
.modal { width: 100%; max-width: 800px; padding: clamp(28px,4vw,48px); border-radius: var(--radius); transform: translateY(30px) scale(.97); transition: transform .5s var(--spring); }
.modal-back.open .modal { transform: none; }
.modal-close { position: absolute; top: 20px; right: 20px; width: 42px; height: 42px; border-radius: 50%; background: var(--glass-2); border: 1px solid var(--brd); display: grid; place-items: center; transition: transform .35s var(--spring), background .25s, color .25s; }
.modal-close:hover { background: var(--accent); color: #fff; transform: rotate(90deg); }
.modal h2 { font-size: clamp(1.6rem,3.2vw,2.3rem); margin: 12px 0 8px; padding-right: 48px; }
.modal .m-block { margin-top: 24px; }
.modal .m-block h4 { font-family: var(--font-mono); font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: .05em; color: var(--accent); margin-bottom: 11px; }
.modal .m-block p { color: var(--muted); }
.modal .m-list { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.modal .m-list li { display: flex; gap: 11px; color: var(--muted); font-size: 15px; }
.modal .m-list li::before { content: "▸"; color: var(--accent); flex-shrink: 0; }

/* ---------- Timeline ---------- */
/* ---------- Experience — spine timeline ---------- */
.timeline { display: flex; flex-direction: column; }
.xp-item { display: grid; grid-template-columns: 28px 150px minmax(0,1fr); gap: 22px; align-items: stretch; padding-bottom: 16px; }
.xp-rail { position: relative; display: flex; justify-content: center; }
.xp-rail::before { content: ""; position: absolute; top: 0; bottom: 0; width: 2px; background: linear-gradient(var(--accent), color-mix(in oklab,var(--accent) 12%, transparent)); opacity: .35; }
.xp-item:first-child .xp-rail::before { top: 28px; }
.xp-item:last-child .xp-rail::before { bottom: calc(100% - 28px); }
.xp-node { position: relative; z-index: 1; width: 16px; height: 16px; border-radius: 50%; margin-top: 22px; background: var(--accent); box-shadow: 0 0 0 5px color-mix(in oklab,var(--accent) 18%, transparent), inset 0 1px 0 rgba(255,255,255,.5); flex-shrink: 0; transition: transform .4s var(--spring); }
.xp-item:hover .xp-node { transform: scale(1.25); }
.xp-year { font-family: var(--font-mono); font-size: 12.5px; font-weight: 600; color: var(--accent); padding-top: 24px; text-align: right; }
.xp-card { padding: 22px 24px; border-radius: var(--radius-sm); transition: transform .4s var(--ease); }
.xp-card:hover { transform: translateX(5px); }
.xp-org { display: flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 12.5px; color: var(--muted); margin-bottom: 10px; }
.xp-badge { width: 30px; height: 30px; border-radius: 9px; background: color-mix(in oklab,var(--accent) 16%, transparent); color: var(--accent); display: grid; place-items: center; font-family: var(--font-display); font-weight: 800; font-size: 12px; flex-shrink: 0; }
.xp-card h3 { font-size: clamp(1.1rem,1.7vw,1.32rem); }
.xp-card p { color: var(--muted); font-size: 14.5px; margin-top: 8px; }

/* ---------- Education — diploma cards ---------- */
.edu-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 16px; }
.edu-card { position: relative; padding: 26px; border-radius: var(--radius); overflow: hidden; transition: transform .45s var(--ease); }
.edu-card::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: linear-gradient(var(--accent), var(--accent-2)); }
.edu-card:hover { transform: translateY(-5px); }
.edu-top { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 18px; }
.edu-seal { width: 50px; height: 50px; border-radius: 14px; background: var(--glass-2); border: 1px solid var(--brd-soft); display: grid; place-items: center; color: var(--accent); box-shadow: inset 0 1px 0 var(--hi); }
.edu-seal svg { width: 24px; height: 24px; }
.edu-date { font-family: var(--font-mono); font-size: 12px; font-weight: 600; color: var(--muted); padding: 6px 12px; border-radius: 100px; background: var(--glass-2); border: 1px solid var(--brd-soft); }
.edu-card h3 { font-size: clamp(1.1rem,1.7vw,1.3rem); line-height: 1.2; }
.edu-org { font-family: var(--font-mono); font-size: 12.5px; color: var(--faint); margin-top: 10px; display: block; }

/* ---------- Skills — bento ---------- */
.skills-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 16px; }
.skill-panel { position: relative; padding: 26px; border-radius: var(--radius); overflow: hidden; }
.skill-panel .sk-num { position: absolute; top: 14px; right: 20px; font-family: var(--font-display); font-weight: 800; font-size: 3.4rem; line-height: 1; color: var(--sc); opacity: .1; letter-spacing: -.04em; }
.sk-head { display: flex; align-items: center; gap: 14px; margin-bottom: 20px; }
.sk-ic { width: 48px; height: 48px; border-radius: 14px; background: color-mix(in oklab,var(--sc) 16%, transparent); color: var(--sc); display: grid; place-items: center; flex-shrink: 0; box-shadow: inset 0 1px 0 var(--hi); }
.sk-ic svg { width: 24px; height: 24px; }
.sk-meta h4 { font-size: 1.15rem; font-weight: 700; }
.sk-count { font-family: var(--font-mono); font-size: 11.5px; color: var(--faint); text-transform: uppercase; letter-spacing: .03em; }
.sk-chips { display: flex; flex-wrap: wrap; gap: 9px; }
.sk-chip { font-weight: 600; font-size: 14px; padding: 8px 15px; border-radius: 100px; background: var(--glass-2); border: 1px solid var(--brd-soft); transition: transform .3s var(--spring), border-color .25s, color .25s; cursor: default; }
.sk-chip:hover { transform: translateY(-3px); border-color: var(--sc); color: var(--sc); }
.sk-chip.lead { background: color-mix(in oklab,var(--sc) 18%, transparent); border-color: color-mix(in oklab,var(--sc) 40%, transparent); color: var(--sc); }

/* ---------- About photo / gallery ---------- */
.about-grid { display: grid; grid-template-columns: minmax(0,1.3fr) minmax(0,.9fr); gap: 34px; align-items: center; }
.about-photo { padding: 12px; border-radius: var(--radius); }
.about-photo img { width: 100%; aspect-ratio: 4/5; object-fit: cover; border-radius: var(--radius-sm); }
.about-contact { margin-top: 22px; display: flex; flex-direction: column; }
.about-contact a { display: flex; align-items: center; gap: 13px; padding: 14px 0; border-top: 1px solid var(--brd-soft); font-weight: 600; font-size: 14.5px; transition: color .25s, padding-left .3s var(--ease); }
.about-contact a:last-child { border-bottom: 1px solid var(--brd-soft); }
.about-contact a:hover { color: var(--accent); padding-left: 7px; }
.about-contact a svg { width: 17px; height: 17px; color: var(--accent); }
.about-contact a .k { font-family: var(--font-mono); font-size: 11px; color: var(--faint); width: 58px; flex-shrink: 0; }
.gallery { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 14px; }
.gallery .g-item { padding: 7px; border-radius: var(--radius-sm); }
.gallery img { width: 100%; aspect-ratio: 1/1; object-fit: cover; border-radius: 11px; }

/* ---------- Forum ---------- */
.forum-grid { display: grid; grid-template-columns: minmax(0,1fr) 290px; gap: 20px; align-items: start; }
.forum-stats { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 12px; margin-bottom: 18px; }
.fstat { padding: 18px; border-radius: var(--radius-sm); text-align: left; }
.fstat b { font-family: var(--font-display); font-weight: 800; font-size: 1.6rem; display: block; line-height: 1; }
.fstat span { font-family: var(--font-mono); font-size: 10.5px; color: var(--faint); text-transform: uppercase; }
.threads { display: flex; flex-direction: column; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--brd); background: var(--glass-2); }
.thread { display: grid; grid-template-columns: auto minmax(0,1fr) auto; gap: 16px; align-items: center; padding: 18px 20px; cursor: pointer; transition: background .25s; }
.thread + .thread { border-top: 1px solid var(--brd-soft); }
.thread:hover { background: var(--glass-3); }
.thread .avatar { width: 44px; height: 44px; border-radius: 13px; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; color: #fff; font-size: 15px; flex-shrink: 0; box-shadow: inset 0 1px 0 rgba(255,255,255,.35); }
.thread .t-body h3 { font-size: 1.05rem; line-height: 1.3; }
.thread .t-meta { display: flex; flex-wrap: wrap; gap: 7px 12px; margin-top: 6px; font-size: 12px; color: var(--faint); font-family: var(--font-mono); align-items: center; }
.thread .t-cat { padding: 3px 9px; border-radius: 100px; font-size: 10.5px; font-weight: 600; }
.thread .t-stats { display: flex; gap: 16px; flex-shrink: 0; }
.thread .t-stats .s { display: flex; flex-direction: column; gap: 1px; text-align: center; }
.thread .t-stats .s b { font-family: var(--font-display); font-size: 1.05rem; }
.thread .t-stats .s span { font-family: var(--font-mono); font-size: 10px; color: var(--faint); text-transform: uppercase; }
.forum-widget { padding: 20px; border-radius: var(--radius); }
.forum-widget + .forum-widget { margin-top: 16px; }
.forum-widget h4 { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--faint); margin-bottom: 14px; }
.member-row { display: flex; align-items: center; gap: 11px; padding: 8px 0; }
.member-row .avatar { width: 36px; height: 36px; border-radius: 11px; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; color: #fff; font-size: 13px; }
.member-row .m-name { font-weight: 700; font-size: 13.5px; }
.member-row .m-role { font-size: 11.5px; color: var(--faint); font-family: var(--font-mono); }
.member-row .m-online { width: 8px; height: 8px; border-radius: 50%; background: #28c840; margin-left: auto; }
.tagcloud { display: flex; flex-wrap: wrap; gap: 7px; }

/* ---------- Login ---------- */
.login-wrap { display: flex; align-items: center; justify-content: center; min-height: calc(100vh - var(--bar) - 80px); padding: 30px 0; }
.login-card { width: 100%; max-width: 430px; padding: clamp(28px,4vw,42px); border-radius: var(--radius); }
.login-card .badge { width: 54px; height: 54px; border-radius: 16px; background: var(--accent); display: grid; place-items: center; color: #fff; margin-bottom: 20px; box-shadow: inset 0 1px 0 rgba(255,255,255,.4), 0 10px 24px -8px var(--accent); }
.login-card .badge svg { width: 26px; height: 26px; }
.login-card h1 { font-size: clamp(1.7rem,3.4vw,2.2rem); margin: 4px 0 7px; }
.oauth-row { display: flex; flex-direction: column; gap: 11px; margin: 24px 0; }
.oauth-btn { display: flex; align-items: center; justify-content: center; gap: 11px; padding: 14px; border-radius: 14px; background: var(--glass-2); border: 1px solid var(--brd); font-weight: 600; font-size: 14.5px; transition: transform .35s var(--spring), border-color .25s; box-shadow: inset 0 1px 0 var(--hi); }
.oauth-btn:hover { transform: translateY(-2px); border-color: var(--accent); }
.oauth-btn svg { width: 19px; height: 19px; }
.divider { display: flex; align-items: center; gap: 14px; color: var(--faint); font-family: var(--font-mono); font-size: 11.5px; margin: 2px 0 20px; }
.divider::before, .divider::after { content: ""; flex: 1; height: 1px; background: var(--brd-soft); }
.field { margin-bottom: 15px; }
.field label { display: block; font-family: var(--font-mono); font-size: 11.5px; color: var(--muted); margin-bottom: 7px; text-transform: uppercase; letter-spacing: .04em; }
.field input { width: 100%; padding: 13px 15px; border-radius: 13px; background: var(--glass-2); border: 1px solid var(--brd); color: var(--text); font-family: var(--font-body); font-size: 14.5px; transition: border-color .25s, box-shadow .25s; }
.field input::placeholder { color: var(--faint); }
.field input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-soft); }
.field input.err { border-color: #ff5f57; }
.field .err-msg { color: #ff5f57; font-size: 12px; margin-top: 6px; font-family: var(--font-mono); display: none; }
.field input.err ~ .err-msg { display: block; }
.login-foot { text-align: center; margin-top: 18px; font-size: 13.5px; color: var(--muted); }
.login-foot a { color: var(--accent); font-weight: 700; }
.login-back { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-mono); font-size: 12.5px; color: var(--muted); margin-bottom: 16px; transition: gap .3s, color .25s; }
.login-back:hover { color: var(--accent); gap: 11px; }

/* ---------- Footer ---------- */
.foot { margin-top: 34px; padding-top: 24px; border-top: 1px solid var(--brd-soft); display: flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; font-family: var(--font-mono); font-size: 12px; color: var(--muted); }
.foot-social { display: flex; gap: 8px; }

/* ---------- Reveal ---------- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal[data-d="1"]{transition-delay:.06s}.reveal[data-d="2"]{transition-delay:.12s}.reveal[data-d="3"]{transition-delay:.18s}.reveal[data-d="4"]{transition-delay:.24s}
@media (prefers-reduced-motion: reduce){ .reveal{opacity:1;transform:none;transition:none} .aurora span,.banner .orb{animation:none} *{animation-duration:.001s!important} }

/* ---------- i18n ---------- */
html[data-lang="fr"] [data-lang-en], html[data-lang="en"] [data-lang-fr] { display: none !important; }

/* ---------- Placeholders (user-fillable) ---------- */
.ph-l { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .02em; padding: 4px 10px; border-radius: 100px; background: rgba(0,0,0,.28); color: #fff; backdrop-filter: blur(4px); white-space: nowrap; }

/* card image carousel */
.c-shots { position: relative; height: 158px; border-radius: 14px; overflow: hidden; margin-bottom: 16px; border: 1px solid var(--brd-soft); }
.c-track { display: flex; width: 300%; height: 100%; animation: slide3 10s var(--ease) infinite; }
.card:hover .c-track { animation-play-state: paused; }
.c-shot { width: 33.3333%; height: 100%; flex-shrink: 0; display: grid; place-items: center; position: relative; }
.c-shot::after { content: ""; position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(255,255,255,.07) 0 2px, transparent 2px 14px); }
.c-shot .ph-l { position: relative; z-index: 1; }
@keyframes slide3 { 0%,28% { transform: translateX(0); } 33%,61% { transform: translateX(-33.3333%); } 66%,94% { transform: translateX(-66.6666%); } 100% { transform: translateX(0); } }
.c-idx-badge { position: absolute; top: 10px; left: 10px; z-index: 2; font-family: var(--font-mono); font-size: 11px; font-weight: 600; padding: 4px 10px; border-radius: 100px; background: rgba(0,0,0,.3); color: #fff; backdrop-filter: blur(4px); }
.c-dots { position: absolute; bottom: 10px; right: 12px; z-index: 2; display: flex; gap: 5px; }
.c-dots i { width: 6px; height: 6px; border-radius: 50%; background: rgba(255,255,255,.5); animation: dotcy 10s var(--ease) infinite; }
.c-dots i:nth-child(1) { animation-delay: 0s; } .c-dots i:nth-child(2) { animation-delay: 3.3s; } .c-dots i:nth-child(3) { animation-delay: 6.6s; }
@keyframes dotcy { 0%,28% { background: #fff; transform: scale(1.3); } 33%,100% { background: rgba(255,255,255,.5); transform: scale(1); } }

/* modal media */
.m-media { display: grid; gap: 12px; }
.m-video { position: relative; aspect-ratio: 16/9; border-radius: 16px; display: flex; align-items: flex-end; padding: 16px; overflow: hidden; }
.m-video::after { content: ""; position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(255,255,255,.06) 0 2px, transparent 2px 16px); }
.m-video .m-play { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 62px; height: 62px; border-radius: 50%; background: rgba(255,255,255,.92); display: grid; place-items: center; z-index: 2; box-shadow: 0 10px 30px -8px rgba(0,0,0,.4); transition: transform .35s var(--spring); }
.m-video:hover .m-play { transform: translate(-50%,-50%) scale(1.08); }
.m-video .m-play svg { width: 24px; height: 24px; color: #1a1a2e; margin-left: 3px; }
.m-video .ph-l { position: relative; z-index: 2; }
.m-thumbs { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.m-thumbs .c-shot { aspect-ratio: 4/3; height: auto; border-radius: 12px; overflow: hidden; }
.m-media + * { margin-top: 0; }

/* ---------- BLOG ---------- */
.blog-featured { display: grid; grid-template-columns: minmax(0,1.05fr) minmax(0,1fr); gap: 0; border-radius: var(--radius); overflow: hidden; margin-bottom: 24px; }
.blog-featured .feat-cover { position: relative; min-height: 280px; display: flex; align-items: flex-end; padding: 18px; }
.blog-featured .feat-cover::after { content: ""; position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(255,255,255,.07) 0 2px, transparent 2px 16px); }
.blog-featured .feat-cover .t-cat { position: relative; z-index: 1; }
.blog-featured .feat-cover .ph-l { position: absolute; top: 16px; right: 16px; }
.blog-featured .feat-body { padding: clamp(24px,3vw,38px); display: flex; flex-direction: column; justify-content: center; }
.blog-featured .feat-body h2 { font-size: clamp(1.4rem,2.4vw,2rem); margin: 12px 0 12px; line-height: 1.1; }
.blog-featured .feat-body p { font-size: 15px; line-height: 1.55; }
.post-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 16px; }
.post-card { border-radius: var(--radius); overflow: hidden; cursor: pointer; transition: transform .45s var(--ease), box-shadow .45s var(--ease); display: flex; flex-direction: column; }
.post-card:hover { transform: translateY(-7px) scale(1.012); box-shadow: var(--shadow), 0 30px 60px -22px var(--accent-soft), inset 0 1.5px 0 var(--hi); }
.post-cover { position: relative; aspect-ratio: 16/10; display: flex; align-items: flex-end; padding: 14px; }
.post-cover::after { content: ""; position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(255,255,255,.07) 0 2px, transparent 2px 16px); }
.post-cover .t-cat { position: relative; z-index: 1; padding: 4px 11px; border-radius: 100px; font-size: 11px; font-weight: 700; font-family: var(--font-mono); }
.post-cover .ph-l { position: absolute; top: 12px; right: 12px; }
.post-body { padding: 20px 22px 22px; display: flex; flex-direction: column; flex: 1; }
.post-body h3 { font-size: 1.18rem; line-height: 1.25; margin-bottom: 9px; }
.post-meta { display: flex; flex-wrap: wrap; gap: 6px 12px; margin-top: auto; padding-top: 14px; font-family: var(--font-mono); font-size: 12px; color: var(--faint); }
.t-cat { padding: 4px 11px; border-radius: 100px; font-size: 11px; font-weight: 700; font-family: var(--font-mono); }

/* ---------- Responsive ---------- */
@media (max-width: 1080px) {
  .cards { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .skills-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .forum-grid { grid-template-columns: minmax(0,1fr); }
  .post-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .edu-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .forum-stats { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .forum-aside { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 16px; }
  .forum-widget + .forum-widget { margin-top: 0; }
  .winbody { grid-template-columns: 218px minmax(0,1fr); }
}
@media (max-width: 860px) {
  .winbody { grid-template-columns: 1fr; }
  .sidebar { display: none; }
  .win-tabs { display: none; }
  .burger { display: grid; }
  .banner .b-inner { max-width: 100%; }
  .banner .orb { opacity: .35; right: -120px; }
  .banner-hero { grid-template-columns: 1fr; gap: 26px; }
  .banner-hero .b-photo { justify-self: start; max-width: 280px; order: -1; }
  .about-grid { grid-template-columns: 1fr; gap: 26px; }
  .xp-item { grid-template-columns: 24px minmax(0,1fr); gap: 0 16px; }
  .xp-rail { grid-row: 1 / -1; }
  .xp-year { grid-column: 2; text-align: left; padding-top: 22px; padding-bottom: 6px; }
  .xp-card { grid-column: 2; margin-bottom: 0; }
  .forum-stats { grid-template-columns: 1fr 1fr; }
  .blog-featured { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .cards, .post-grid { grid-template-columns: 1fr; }
  .skills-grid, .gallery, .forum-aside, .edu-grid { grid-template-columns: 1fr; }
  .content { padding: 20px 16px; }
  .win-tools .btn { display: none; }
  .desktop { padding: 8px; }
  .winbar { padding: 10px 12px; gap: 8px; }
  .m-thumbs { grid-template-columns: 1fr 1fr; }
  .foot { flex-direction: column; align-items: flex-start; gap: 14px; }
}
@media (max-width: 430px) {
  .avatar-chip { display: none; }
  .content-head .ch-title { font-size: 1.2rem; }
  .banner-hero .b-photo { max-width: 100%; }
  .winbar .lights { display: none; }
  .stat .num, .fstat b { font-size: 1.5rem; }
}
