*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg: #f8f9fa;
  --surface: rgba(255, 255, 255, 0.7);
  --border: rgba(0, 0, 0, 0.08);
  --accent: #333;
  --accent2: #555;
  --text: #1a1a1a;
  --dim: #666;
  --mono: 'JetBrains Mono', monospace;
  --sans: 'Inter', system-ui, sans-serif;
  --glass: rgba(255, 255, 255, 0.4);
  --card-bg: rgba(255, 255, 255, 0.5);
  --card-border: rgba(0, 0, 0, 0.05);
}

.dark {
  --bg: #0d0e14;
  --surface: rgba(25, 27, 34, 0.7);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #fff;
  --accent2: #00ff88;
  --text: #eee;
  --dim: #999;
  --glass: rgba(0, 0, 0, 0.4);
  --card-bg: rgba(255, 255, 255, 0.05);
  --card-border: rgba(255, 255, 255, 0.1);
}



html,body{width:100%;height:100%;overflow:hidden;font-family:var(--sans);color:var(--text);background:var(--bg)}

/* ===== BOOT ===== */
#boot{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:999;transition:opacity .8s}
#boot.done{opacity:0;pointer-events:none}
.boot-box{text-align:center;width:200px}
.boot-logo{width:48px;height:48px;margin:0 auto 20px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(108,92,231,.4)}50%{box-shadow:0 0 0 14px rgba(108,92,231,0)}}
.boot-bar-track{width:100%;height:3px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden}
.boot-bar-fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:2px;transition:width .3s}
.boot-msg{margin-top:12px;font-size:12px;color:var(--dim);font-family:var(--mono)}

/* ===== 3D SCENE ===== */
#scene{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg);z-index:99;cursor:pointer;opacity:0;transition:opacity .8s ease}
.scene-bg{position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 50% 55%,rgba(108,92,231,.12) 0%,transparent 55%),
    radial-gradient(ellipse at 30% 30%,rgba(0,206,201,.08) 0%,transparent 45%),
    radial-gradient(ellipse at 70% 70%,rgba(108,92,231,.06) 0%,transparent 40%);
  animation:bgPulse 6s ease-in-out infinite alternate}
@keyframes bgPulse{
  0%{background:radial-gradient(ellipse at 50% 55%,rgba(108,92,231,.12),transparent 55%),radial-gradient(ellipse at 30% 30%,rgba(0,206,201,.08),transparent 45%),radial-gradient(ellipse at 70% 70%,rgba(108,92,231,.06),transparent 40%)}
  100%{background:radial-gradient(ellipse at 50% 55%,rgba(108,92,231,.18),transparent 55%),radial-gradient(ellipse at 25% 35%,rgba(0,206,201,.12),transparent 45%),radial-gradient(ellipse at 75% 65%,rgba(108,92,231,.1),transparent 40%)}
}
.scene-content{position:relative;display:flex;flex-direction:column;align-items:center;gap:50px}

/* Monitor wrapper */
.monitor-wrapper{position:relative;perspective:1200px;transition:transform 1.8s cubic-bezier(.16,1,.3,1),opacity .8s;transform-origin:center 40%;animation:float 5s ease-in-out infinite}
.monitor-wrapper.zoom{transform:scale(4.5) translateY(5%)!important;opacity:0}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* Monitor */
.monitor{width:460px;height:300px;background:linear-gradient(145deg,#32353e,#24262e);border-radius:16px;padding:12px;position:relative;
  box-shadow:0 25px 70px rgba(0,0,0,.5),0 0 100px rgba(108,92,231,.1),0 0 200px rgba(108,92,231,.04);
  transform:rotateX(4deg);transition:transform .6s,box-shadow .6s}
.monitor:hover{transform:rotateX(2deg) translateY(-4px);box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 120px rgba(108,92,231,.15),0 0 250px rgba(108,92,231,.06)}

/* Screen with glow */
.monitor-screen{width:100%;height:100%;background:linear-gradient(135deg,#0d0e14,#121420);border-radius:8px;overflow:hidden;position:relative;
  box-shadow:inset 0 0 40px rgba(108,92,231,.1),0 0 30px rgba(108,92,231,.06);
  animation:screenGlow 4s ease-in-out infinite alternate}
@keyframes screenGlow{0%{box-shadow:inset 0 0 40px rgba(108,92,231,.08),0 0 30px rgba(108,92,231,.05)}100%{box-shadow:inset 0 0 50px rgba(108,92,231,.14),0 0 40px rgba(108,92,231,.08)}}
.monitor-screen::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.03) 0%,transparent 40%);pointer-events:none}
.monitor-screen::before{content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.06) 3px,rgba(0,0,0,.06) 4px);
  pointer-events:none;z-index:2;opacity:.4}

/* Screen UI content */
.screen-ui{padding:14px 16px;position:relative;z-index:1}
.screen-topbar{display:flex;gap:6px;margin-bottom:16px}
.screen-dot{width:8px;height:8px;border-radius:50%}
.screen-dot.r{background:#ff5f57;box-shadow:0 0 6px rgba(255,95,87,.5)}
.screen-dot.y{background:#ffbd2e;box-shadow:0 0 6px rgba(255,189,46,.5)}
.screen-dot.g{background:#28c840;box-shadow:0 0 6px rgba(40,200,64,.5)}
.screen-lines span{display:block;height:6px;border-radius:3px;margin:10px 0;opacity:0;animation:lineIn .4s ease forwards}
.screen-lines span:nth-child(1){width:65%;background:linear-gradient(90deg,rgba(108,92,231,.25),rgba(108,92,231,.08));animation-delay:.3s}
.screen-lines span:nth-child(2){width:45%;background:linear-gradient(90deg,rgba(0,206,201,.25),rgba(0,206,201,.08));animation-delay:.5s}
.screen-lines span:nth-child(3){width:80%;background:linear-gradient(90deg,rgba(108,92,231,.2),rgba(108,92,231,.06));animation-delay:.7s}
.screen-lines span:nth-child(4){width:35%;background:linear-gradient(90deg,rgba(0,206,201,.2),rgba(0,206,201,.06));animation-delay:.9s}
.screen-lines span:nth-child(5){width:55%;background:linear-gradient(90deg,rgba(108,92,231,.15),rgba(108,92,231,.04));animation-delay:1.1s}
@keyframes lineIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}

/* Monitor frame */
.monitor-chin{width:100%;height:12px;background:linear-gradient(145deg,#32353e,#24262e);border-radius:0 0 16px 16px;margin-top:-2px}
.monitor-stand{width:55px;height:45px;background:linear-gradient(180deg,#32353e,#282a32);margin:0 auto;clip-path:polygon(15% 0,85% 0,100% 100%,0 100%)}
.monitor-base{width:120px;height:10px;background:linear-gradient(180deg,#282a32,#1e2028);margin:0 auto;border-radius:5px 5px 3px 3px;box-shadow:0 4px 12px rgba(0,0,0,.3)}

/* Desk surface */
.desk-surface{position:absolute;bottom:-90px;left:50%;transform:translateX(-50%);width:650px;height:35px;
  background:linear-gradient(90deg,#1e2028,#282a32,#1e2028);border-radius:8px;
  box-shadow:0 6px 25px rgba(0,0,0,.4),0 0 40px rgba(108,92,231,.03)}

/* Desk items */
.desk-item{position:absolute}
.keyboard{bottom:-72px;left:50%;transform:translateX(-50%);width:170px;height:55px;
  background:linear-gradient(145deg,#24262e,#1a1c22);border-radius:6px;
  box-shadow:0 3px 10px rgba(0,0,0,.3),0 0 20px rgba(108,92,231,.02)}
.keyboard::before{content:'';position:absolute;inset:5px;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.04) 0 9px,transparent 9px 11px);border-radius:4px}
.keyboard::after{content:'';position:absolute;top:50%;left:20%;right:20%;height:1px;background:rgba(255,255,255,.03)}

.mouse-pad{bottom:-68px;right:65px;width:28px;height:44px;background:linear-gradient(180deg,#22242c,#1a1c22);border-radius:12px 12px 14px 14px;
  box-shadow:0 2px 8px rgba(0,0,0,.25);animation:mouseGlow 3s ease-in-out infinite alternate}
@keyframes mouseGlow{0%{box-shadow:0 2px 8px rgba(0,0,0,.25)}100%{box-shadow:0 2px 8px rgba(0,0,0,.25),0 0 8px rgba(108,92,231,.08)}}

/* Plant with sway */
.plant{bottom:-55px;left:20px;width:40px;height:60px;position:absolute}
.plant-pot{position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:28px;height:26px;
  background:linear-gradient(145deg,#d4845a,#b06840);border-radius:3px 3px 7px 7px;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.plant-leaf{position:absolute;width:18px;height:18px;border-radius:50% 0;background:#34a853;transform-origin:bottom center}
.plant-leaf.l1{bottom:24px;left:2px;transform:rotate(-30deg);animation:sway 3s ease-in-out infinite;background:linear-gradient(135deg,#34a853,#2d8a4e)}
.plant-leaf.l2{bottom:32px;left:10px;transform:rotate(10deg);animation:sway 3.5s ease-in-out infinite .3s;background:linear-gradient(135deg,#3cb85c,#34a853)}
.plant-leaf.l3{bottom:26px;left:18px;transform:rotate(40deg);animation:sway 2.8s ease-in-out infinite .6s;background:linear-gradient(135deg,#2d8a4e,#247a3e)}
@keyframes sway{0%,100%{transform:rotate(var(--r,10deg))}50%{transform:rotate(calc(var(--r,10deg) + 6deg))}}
.plant-leaf.l1{--r:-30deg}.plant-leaf.l2{--r:10deg}.plant-leaf.l3{--r:40deg}

/* Mug with steam */
.mug{bottom:-62px;right:25px;width:22px;height:28px;
  background:linear-gradient(145deg,#f5f5f5,#ddd);border-radius:3px 3px 5px 5px;box-shadow:0 3px 8px rgba(0,0,0,.25)}
.mug::after{content:'';position:absolute;right:-7px;top:5px;width:9px;height:14px;border:2px solid #ddd;border-left:none;border-radius:0 7px 7px 0}
.mug::before{content:'';position:absolute;top:-14px;left:50%;width:2px;height:12px;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.15));
  border-radius:2px;animation:steam 2s ease-in-out infinite;transform-origin:bottom}
@keyframes steam{0%{opacity:0;transform:translateX(-50%) translateY(0) scaleY(.5)}50%{opacity:.6}100%{opacity:0;transform:translateX(-50%) translateY(-10px) scaleY(1.2)}}

/* Prompt */
.scene-prompt{font-family:var(--mono);font-size:15px;color:rgba(237,240,247,.5);letter-spacing:.5px;
  animation:promptFade 2s ease-in-out infinite alternate}
@keyframes promptFade{0%{opacity:.4;color:rgba(237,240,247,.4)}100%{opacity:1;color:rgba(237,240,247,.7)}}
.blink{animation:blink .8s step-end infinite;color:var(--accent)}
@keyframes blink{50%{opacity:0}}

/* ===== DESKTOP ===== */
#desktop{position:fixed;inset:0;background:#000;overflow:hidden;--wallpaper: url('assets/img/IMG_3288.png')}
#desktop::before{content:'';position:absolute;inset:0;background:var(--wallpaper) center/cover;filter:none;opacity:1;z-index:0;transition: background 0.5s ease;}

#desktop.show{display:block!important;animation:fadeUp .6s ease forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ===== TOP BAR ===== */
#top-bar{position:fixed;top:0;left:0;right:0;height:30px;background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:space-between;padding:0 16px;font-size:13px;font-weight:500;z-index:10000;border-bottom:1px solid var(--border);color:var(--text);transition: background 0.3s, color 0.3s;}

.top-bar-left, .top-bar-right{display:flex;align-items:center;gap:20px}
.top-logo{font-size:16px;font-weight:800;cursor:pointer;color:var(--accent)}
.top-menu-item{cursor:pointer;color:var(--text);transition:opacity .2s;opacity:.8}
.top-menu-item:hover{opacity:1}
.top-bar-icon{width:16px;height:16px;color:var(--text);cursor:pointer}
.top-bar-clock{color:var(--text);min-width:110px;text-align:right;font-family:var(--mono)}

/* Toggle Switch */
.mode-toggle {
  position: relative;
  width: 42px;
  height: 20px;
  background: rgba(0,0,0,0.1);
  border-radius: 20px;
  cursor: pointer;
  transition: background 0.3s;
  display: flex;
  align-items: center;
  padding: 0 4px;
}
.dark .mode-toggle { background: rgba(255,255,255,0.2); }
.toggle-thumb {
  width: 14px;
  height: 14px;
  background: #fff;
  border-radius: 50%;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 8px;
}
.dark .toggle-thumb { transform: translateX(20px); background: #333; }
.toggle-thumb::after { content: '☀️'; }
.dark .toggle-thumb::after { content: '🌙'; }


/* ===== FLOATING ICONS (PROJECT CLOUD) ===== */
.desktop-icons{position:absolute;inset:0;pointer-events:none;z-index:1}
.desk-icon{position:absolute;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:all;cursor:pointer;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}
.desk-icon:hover{transform:scale(1.1) translateY(-5px)}
.desk-icon-box{width:64px;height:64px;background:rgba(255,255,255,.8);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 25px rgba(0,0,0,.08);overflow:hidden}
.desk-icon-box img{width:100%;height:100%;object-fit:cover}
.desk-icon span{font-size:10px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.5px;opacity:.8}

/* Position mapping */
.i1{top:12%;left:18%}.i2{top:8%;left:28%}.i3{top:15%;left:36%}.i4{top:5%;left:52%}.i5{top:18%;left:60%}.i6{top:32%;left:22%}.i7{top:28%;left:45%}.i8{top:30%;left:70%}.i9{top:42%;left:12%}.i10{top:48%;left:32%}

/* ===== FOLDER ICON (VANILLA) ===== */
.folder-wrapper { position: relative; width: 64px; height: 48px; perspective: 1000px; margin-bottom: 4px; }
.folder-main { position: relative; width: 100%; height: 100%; transform-style: preserve-3d; transition: transform 0.5s; cursor: pointer; }
.desk-icon:hover .folder-main { transform: rotateX(-15deg); }

.folder-back { position: absolute; inset: 0; background: #d97706; border-radius: 8px; border-top-left-radius: 0; }
.folder-back::after { content: ''; position: absolute; bottom: 100%; left: 0; width: 24px; height: 6px; background: #d97706; border-radius: 6px 6px 0 0; }

.folder-front { position: absolute; bottom: 0; width: 100%; height: 38px; background: linear-gradient(to top, #f59e0b, #fbbf24); border-radius: 8px; border-top-right-radius: 0; z-index: 10; transition: transform 0.3s; transform-origin: bottom; box-shadow: 0 -2px 10px rgba(0,0,0,0.1); }
.desk-icon:hover .folder-front { transform: rotateX(-35deg); }

.folder-paper { position: absolute; inset: 4px; background: #f4f4f5; border-radius: 4px; transition: transform 0.4s; z-index: 5; }
.p1 { transform: translateY(-4px); background: #e4e4e7; }
.p2 { transform: translateY(-8px); background: #f4f4f5; }
.p3 { transform: translateY(-12px); background: #fff; }
.desk-icon:hover .p1 { transform: translateY(-12px) rotateX(-10deg); }
.desk-icon:hover .p2 { transform: translateY(-18px) rotateX(-15deg); }
.desk-icon:hover .p3 { transform: translateY(-24px) rotateX(-20deg); }

/* ===== WEATHER WIDGET ===== */
.weather-widget{position:absolute;top:50px;left:20px;width:150px;padding:16px;background:var(--glass);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:20px;color:var(--text);box-shadow:0 10px 30px rgba(0,0,0,0.05);cursor:default;transition:all 0.3s}

.weather-widget:hover{transform:translateY(-5px)}
.w-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.w-icon{font-size:24px}
.w-temp{font-size:22px;font-weight:700}
.w-city{font-size:13px;font-weight:600;margin-bottom:2px}
.w-desc{font-size:11px;color:var(--dim)}

/* ===== SEARCH OVERLAY ===== */
#search-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);backdrop-filter:blur(10px);z-index:20000;display:none;align-items:flex-start;justify-content:center;padding-top:120px}
.search-box{width:600px;background:var(--surface);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:12px;display:flex;align-items:center;padding:16px 20px;box-shadow:0 25px 60px rgba(0,0,0,.3);position:relative}
.search-box svg{width:20px;height:20px;color:var(--dim);margin-right:14px}
#search-input{background:none;border:none;outline:none;color:var(--text);font-size:18px;flex:1}
.search-hint{position:absolute;right:20px;font-size:11px;color:var(--dim)}
.search-hint span{background:var(--card-bg);padding:2px 6px;border-radius:4px;color:var(--text)}
#search-results{width:600px;background:var(--surface);backdrop-filter:blur(20px);border:1px solid var(--border);border-top:none;border-radius:0 0 12px 12px;margin-top:-2px;max-height:300px;overflow-y:auto;display:none}

.search-res-item{padding:12px 20px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:background .2s}
.search-res-item:hover{background:rgba(108,92,231,.2)}
.search-res-item svg{width:16px;height:16px;color:var(--accent)}
.search-res-item div{display:flex;flex-direction:column}
.search-res-item b{font-size:14px}
.search-res-item s{font-size:11px;color:var(--dim);text-decoration:none}

/* ===== WINDOWS ===== */
.win{position:absolute;width:560px;min-height:200px;background:var(--surface);backdrop-filter:blur(40px) saturate(1.8);-webkit-backdrop-filter:blur(40px) saturate(1.8);border:1px solid var(--border);border-radius:14px;box-shadow:0 16px 48px rgba(0,0,0,.08);overflow:hidden;z-index:100;animation:winIn .45s cubic-bezier(.22,1,.36,1);transition: background 0.3s, border-color 0.3s;}

.win.active{box-shadow:0 16px 64px rgba(0,0,0,.12),0 0 0 1px rgba(0,0,0,.02)}
.win.maximized{top:0!important;left:0!important;width:100%!important;height:calc(100% - 72px)!important;border-radius:0}
@keyframes winIn{from{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:none}}
.win.closing{animation:winOut .2s ease forwards}
@keyframes winOut{to{opacity:0;transform:scale(.95) translateY(6px)}}
.win-bar{display:flex;align-items:center;justify-content:space-between;height:40px;padding:0 16px;background:rgba(255,255,255,.02);border-bottom:1px solid var(--border);cursor:grab;user-select:none}
.win-bar:active{cursor:grabbing}
.win-dots{display:flex;gap:7px}
.wd{width:12px;height:12px;border-radius:50%;cursor:pointer;transition:transform .15s}
.wd:hover{transform:scale(1.2)}
.wd.close{background:#ff5f57}.wd.min{background:#ffbd2e}.wd.max{background:#28c840}
.win-name{font-size:13px;font-weight:500;color:var(--dim);position:absolute;left:50%;transform:translateX(-50%)}
.win-body{padding:24px;max-height:440px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(108,92,231,.2) transparent}
.win-body::-webkit-scrollbar{width:4px}
.win-body::-webkit-scrollbar-thumb{background:rgba(108,92,231,.2);border-radius:2px}

/* About */
.about-top{display:flex;align-items:center;gap:16px;margin-bottom:18px}
.avatar{width:60px;height:60px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;flex-shrink:0}
.gradient-text{font-size:22px;font-weight:700;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.role{font-size:13px;color:var(--accent);font-weight:500;margin-top:2px}
.loc{font-size:12px;color:var(--dim);margin-top:1px}
.bio{font-size:13px;line-height:1.7;color:var(--dim);margin-bottom:16px}
.bio strong{color:var(--accent2)}
.tag-group{display:flex;gap:6px;flex-wrap:wrap}
.tag{font-size:11px;padding:4px 12px;background:rgba(108,92,231,.08);border:1px solid rgba(108,92,231,.15);border-radius:20px;color:var(--accent)}

/* Experience */
.timeline-card{display:flex;gap:14px;padding:16px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;margin-bottom:12px;transition:border-color .3s}

.timeline-card:hover{border-color:rgba(108,92,231,.2)}
.tl-badge{width:10px;height:10px;border-radius:50%;background:var(--border);margin-top:5px;flex-shrink:0}
.tl-badge.live{background:var(--accent2);box-shadow:0 0 8px rgba(0,206,201,.5);animation:pulse2 2s infinite}
@keyframes pulse2{0%,100%{box-shadow:0 0 8px rgba(0,206,201,.5)}50%{box-shadow:0 0 16px rgba(0,206,201,.8)}}
.tl-content h3{font-size:15px;font-weight:600;margin-bottom:2px}
.tl-co{font-size:13px;color:var(--accent);font-weight:500}
.tl-date{font-size:11px;color:var(--dim);font-family:var(--mono);margin:4px 0 8px}
.tl-desc{font-size:12px;line-height:1.6;color:var(--dim)}

/* Projects */
.proj-card{border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:14px;transition:all .3s}
.proj-card:hover{border-color:rgba(108,92,231,.25);transform:translateY(-2px);box-shadow:0 12px 32px rgba(108,92,231,.08)}
.proj-banner{height:90px}.b1{background:linear-gradient(135deg,#0f2027,#203a43,#2c5364)}.b2{background:linear-gradient(135deg,#1a0533,#2d1b69,#452c8a)}
.proj-info{padding:16px}
.proj-info h3{font-size:16px;font-weight:600;margin-bottom:3px}
.proj-sub{font-size:11px;color:var(--accent);margin-bottom:8px}
.proj-desc{font-size:12px;line-height:1.5;color:var(--dim);margin-bottom:10px}
.proj-tags{display:flex;gap:5px;flex-wrap:wrap}
.proj-tags span{font-size:10px;padding:3px 10px;background:rgba(108,92,231,.1);border:1px solid rgba(108,92,231,.2);border-radius:16px;color:rgba(108,92,231,.8)}

/* ===== SKILLS BENTO ===== */
.skills-bento{padding:16px!important;max-height:500px!important}
.sk-bento-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.sk-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:12px;transition:all .3s}

.sk-card:hover{background:rgba(255,255,255,.05);border-color:rgba(108,92,231,.2);transform:translateY(-2px)}
.sk-card-header{display:flex;justify-content:space-between;align-items:center}
.sk-card-header h4{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--dim)}
.sk-card-header svg{width:16px;height:16px;color:var(--accent)}

/* Circles */
.sk-circle-group{display:flex;gap:20px;justify-content:center;padding:10px 0}
.sk-circle{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}
.sk-circle svg{width:100%;height:100%;transform:rotate(-90deg)}
.sk-c-bg{fill:none;stroke:rgba(255,255,255,.05);stroke-width:2.8}
.sk-c-fill{fill:none;stroke:var(--accent);stroke-width:2.8;stroke-linecap:round;transition:stroke-dasharray 1.5s cubic-bezier(.4,0,.2,1)}
.sk-c-info{position:absolute;display:flex;flex-direction:column;align-items:center}
.sk-c-info span{font-size:14px;font-weight:700}
.sk-c-info small{font-size:9px;color:var(--dim);text-transform:uppercase}

/* Mini List */
.sk-mini-list{display:flex;flex-direction:column;gap:10px}
.sk-mini-item{display:flex;flex-direction:column;gap:4px}
.sk-mini-item span{font-size:12px;color:var(--dim)}
.sk-m-track{width:100%;height:4px;background:rgba(255,255,255,.05);border-radius:2px;overflow:hidden}
.sk-m-fill{height:100%;width:0;border-radius:2px;transition:width 1s ease-out}

/* Tags Cloud */
.sk-tags-cloud{display:flex;flex-wrap:wrap;gap:6px}
.sk-tag{font-size:11px;padding:4px 10px;background:rgba(108,92,231,.05);border:1px solid var(--border);border-radius:8px;color:var(--dim);position:relative;overflow:hidden}
.sk-tag::after{content:'';position:absolute;bottom:0;left:0;height:2px;width:var(--v);background:var(--accent2);opacity:.5}

/* Tools */
.sk-tools-list{display:flex;flex-wrap:wrap;gap:8px}
.sk-tools-list span{font-size:11px;color:var(--dim);background:rgba(255,255,255,.03);padding:4px 8px;border-radius:4px}

/* Education */
.edu-row{display:flex;align-items:center;gap:14px;padding:16px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;margin-bottom:10px;transition:border-color .3s}

.edu-row:hover{border-color:rgba(108,92,231,.2)}
.edu-badge{width:44px;height:44px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}
.edu-row h3{font-size:14px;font-weight:600;margin-bottom:2px}
.edu-sub{font-size:12px;color:var(--accent)}
.edu-meta{font-size:11px;color:var(--dim);font-family:var(--mono);margin-top:2px}

/* Contact */
.contact-body{text-align:center}
.contact-body h2{margin-bottom:4px}
.contact-sub{font-size:13px;color:var(--dim);margin-bottom:20px}
.c-link{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;text-decoration:none;color:var(--text);margin-bottom:8px;text-align:left;transition:all .3s}

.c-link:hover{border-color:rgba(108,92,231,.2);transform:translateX(4px)}
.c-link svg{width:22px;height:22px;color:var(--accent);flex-shrink:0}
.c-link strong{font-size:13px;display:block}
.c-link small{font-size:12px;color:var(--dim)}

/* Terminal */
.terminal-win{width:640px}
.term-bar{background:rgba(0,0,0,.3)!important}
.term-body{background:rgba(0,0,0,.2);font-family:var(--mono);font-size:13px;min-height:260px;display:flex;flex-direction:column}
#term-out{flex:1;overflow-y:auto;margin-bottom:6px}
#term-out p{margin:2px 0;line-height:1.5;word-break:break-all}
.tg{color:#28c840}.tb{color:var(--accent)}.tr{color:#ff5f57}
.term-in{display:flex;align-items:center;font-size:13px}
.term-in span{white-space:nowrap}
#term-input{background:none;border:none;outline:none;color:var(--text);font-family:var(--mono);font-size:13px;flex:1;margin-left:4px;caret-color:#28c840}

/* ===== DESIGN APP ===== */
.design-win { width: 720px!important; height: 500px!important; }
.design-body { background: var(--bg); padding: 20px!important; position: relative; }
.design-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 20px; }
.design-card { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: 12px; overflow: hidden; cursor: pointer; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); position: relative; }
.design-card:hover { transform: translateY(-5px) scale(1.02); border-color: var(--accent2); box-shadow: 0 10px 25px rgba(0,0,0,0.1); }
.design-thumb { width: 100%; height: 100px; background-size: cover; background-position: center; background-color: rgba(0,0,0,0.05); display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; color: var(--dim); }
.pdf-thumb { background: linear-gradient(135deg, #ff4d4d, #b30000); color: white!important; }
.video-thumb { background: linear-gradient(135deg, #4d79ff, #002db3); color: white!important; }
.design-info { padding: 12px; }
.design-info b { display: block; font-size: 13px; color: var(--text); margin-bottom: 2px; }
.design-info span { font-size: 11px; color: var(--dim); }

/* Viewer Overlay */
#design-viewer { position: absolute; inset: 0; background: var(--bg); z-index: 100; display: flex; flex-direction: column; }
.viewer-nav { padding: 12px 20px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; background: var(--surface); backdrop-filter: blur(10px); }
#viewer-close { cursor: pointer; font-size: 12px; color: var(--accent2); font-weight: 600; padding: 4px 12px; border: 1px solid var(--accent2); border-radius: 20px; transition: all 0.2s; }
#viewer-close:hover { background: var(--accent2); color: var(--bg); }
#viewer-content { flex: 1; display: flex; align-items: center; justify-content: center; padding: 20px; overflow: hidden; }
#viewer-content img, #viewer-content video { max-width: 100%; max-height: 100%; border-radius: 8px; box-shadow: 0 20px 50px rgba(0,0,0,0.2); }
#viewer-content iframe { width: 100%; height: 100%; border: none; border-radius: 8px; }

/* ===== MUSIC PLAYER ===== */
.music-win { width: 450px!important; height: 420px!important; box-shadow: 0 20px 50px rgba(0,0,0,0.5); }
.music-bar { background: #000!important; border-bottom: 1px solid #222!important; }
.music-bar .win-name { color: #1DB954!important; font-weight: 700; }
.music-body { height: 100%; padding: 0!important; background: #000; }

/* ===== PINTEREST WIDGET ===== */
.pin-win{width:380px!important;height:560px!important;background:var(--bg)!important}
.pin-win .win-bar{background:var(--surface);border-bottom:1px solid var(--border)}
.pin-win .win-name{color:var(--text)}

.pin-win .wd{border:1px solid rgba(0,0,0,.1)}
.pin-body{padding:0!important;color:#333;height:calc(100% - 40px)}


/* ===== PINTEREST WIDGET ===== */
.pin-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:16px}
.pin-board-card{display:flex;align-items:center;gap:12px;background:#f9f9f9;border:1px solid #eee;border-radius:12px;padding:8px;transition:all .2s;cursor:pointer}
.pin-board-card:hover{background:#fff;box-shadow:0 8px 20px rgba(0,0,0,.05);transform:translateY(-2px)}
.pin-thumb{width:60px;height:60px;border-radius:8px;background-size:cover;background-position:center;flex-shrink:0}
.pin-info b{display:block;font-size:14px;color:#bd081c} /* Pinterest Red */
.pin-info span{font-size:12px;color:#666}
.pin-footer{text-align:center;border-top:1px solid #eee;padding-top:12px}
.pin-footer p{font-size:11px;color:#999;margin-bottom:8px}
#pin-link{display:inline-block;background:#bd081c;color:white;text-decoration:none;padding:6px 16px;border-radius:20px;font-size:12px;font-weight:600;transition:opacity .2s}
#pin-link:hover{opacity:.8}

/* ===== CONTEXT MENU ===== */
#ctx-menu{position:fixed;width:180px;background:var(--surface);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:10px;padding:6px;box-shadow:0 10px 30px rgba(0,0,0,0.4);z-index:10001;display:none}
.ctx-item{padding:8px 12px;font-size:13px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background .2s;color:var(--text);}

.ctx-item:hover{background:var(--accent);color:white}
.ctx-sep{height:1px;background:var(--border);margin:6px 0}

/* ===== DOCK ===== */
.dock{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--glass);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border:1px solid var(--border);border-radius:18px;z-index:9999;box-shadow:0 20px 50px rgba(0,0,0,.1);transition: background 0.3s, border-color 0.3s;}

.dock-item{width:48px;height:48px;padding:6px;color:#333;border-radius:12px;cursor:pointer;transition:all .2s;position:relative;background:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.5)}
.dock-item:hover{background:white;transform:translateY(-8px) scale(1.2);box-shadow:0 10px 20px rgba(0,0,0,.1)}
.dock-item.open::after{content:'';position:absolute;bottom:4px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:#333}
.dock-item svg{width:100%;height:100%}
.dock-item[data-tip]:hover::before{content:attr(data-tip);position:absolute;top:-40px;left:50%;transform:translateX(-50%);background:rgba(255,255,255,.9);color:#000;font-size:11px;padding:5px 12px;border-radius:8px;white-space:nowrap;pointer-events:none;box-shadow:0 5px 15px rgba(0,0,0,.1)}
.dock-sep{width:1px;height:32px;background:rgba(0,0,0,.1);margin:0 4px}
.terminal-dock{color:#333}

@media(max-width:768px){.win{width:calc(100% - 16px)!important;min-width:unset;left:8px!important}.monitor{width:300px;height:200px}.desk-surface{width:400px}}
