*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
:root{
  --pp:#c9b8f0;--pp2:#b8a0e8;--pp3:#8b6fd4;--pp4:#6820ae;
  --bg:#040408;--bg2:#07060f;--bg3:#0c0a1a;--bg4:#100e20;
  --t1:#ffffff;--t2:#c5bedd;--t3:#5a546e;--t4:#3a3450;
  --b1:rgba(180,150,240,.07);--b2:rgba(180,150,240,.18);--b3:rgba(180,150,240,.36);
  --g1:0 0 22px 6px rgba(180,150,240,.30);
  --g2:0 0 45px 12px rgba(140,100,220,.18);
  --r1:8px;--r2:14px;--r3:20px;--r4:28px;
  --ease:cubic-bezier(.16,1,.3,1);
}
body{background:var(--bg);color:var(--t2);font-family:'DM Sans','Segoe UI',system-ui,sans-serif;font-size:1rem;line-height:1.72;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body.intro-lock{overflow:hidden}
body.intro-lock nav,body.intro-lock #prog,body.intro-lock #stop,body.intro-lock .page,body.intro-lock #beam-c{opacity:0;pointer-events:none}
nav,#prog,#stop,.page,#beam-c{transition:opacity 0.5s ease}

#intro{position:fixed;inset:0;z-index:99998;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity 0.8s var(--ease),visibility 0.8s var(--ease)}
#intro.exit{opacity:0;visibility:hidden;pointer-events:none}
#preloader{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.9rem;z-index:3;transition:opacity .55s ease,transform .55s var(--ease)}
#preloader.done{opacity:0;transform:translateY(-14px);pointer-events:none}
.pre-kt{font-family:'Cinzel',serif;font-weight:600;font-size:clamp(52px,12vmin,96px);letter-spacing:-.04em;background:linear-gradient(170deg,#e8d8ff 0%,#a068e8 52%,#4a10a0 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:fadeUp .9s var(--ease) both;user-select:none}
.pre-bar-wrap{width:clamp(120px,28vw,220px);height:2px;background:rgba(180,150,240,.12);border-radius:999px;overflow:hidden}
.pre-bar{height:100%;width:0;background:linear-gradient(90deg,var(--pp3),var(--pp));border-radius:999px;transition:width .04s linear}
.pre-pct{font-family:'Raleway',sans-serif;font-weight:200;font-size:clamp(7px,1.2vmin,10px);letter-spacing:.32em;color:rgba(170,105,228,.42);text-transform:uppercase}
.intro-content{transition:opacity .65s var(--ease)}
#stars{position:absolute;inset:0;z-index:1;pointer-events:none}
#intro-beam{position:absolute;inset:0;z-index:0;pointer-events:none}
.s{position:absolute;background:#fff;border-radius:50%;animation:tw var(--d) ease-in-out infinite var(--dl)}
@keyframes tw{0%,100%{opacity:var(--lo)}50%{opacity:var(--hi)}}
.intro-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;text-align:center}
.kt{display:flex;align-items:flex-end;justify-content:center;width:100%;margin-bottom:clamp(14px,3vw,26px);animation:fadeUp 1.5s var(--ease) 0.1s both}
.kt-text{font-family:'Cinzel',serif;font-weight:600;font-size:clamp(90px,20vmin,190px);line-height:1;letter-spacing:-0.05em;background:linear-gradient(170deg,#e8d8ff 0%,#d0b4ff 18%,#a068e8 52%,#7028c0 80%,#4a10a0 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 4px rgba(210,170,255,0.5)) drop-shadow(0 0 18px rgba(155,75,235,0.40)) drop-shadow(0 0 48px rgba(95,25,185,0.25));user-select:none}
.intro-name{font-family:'Cinzel',serif;font-weight:400;font-size:clamp(11px,2.6vmin,20px);letter-spacing:0.55em;margin-left:0.55em;color:#ae70e4;text-transform:uppercase;animation:fadeUp 1.5s var(--ease) 0.4s both;text-shadow:0 0 4px rgba(255,255,255,0.3),0 0 18px rgba(155,75,235,0.40)}
.intro-sub{font-family:'Raleway',sans-serif;font-weight:200;font-size:clamp(7px,1.3vmin,10px);letter-spacing:0.35em;margin-left:0.35em;color:rgba(170,105,228,0.5);text-transform:uppercase;margin-top:clamp(7px,1.5vw,14px);animation:fadeUp 1.5s var(--ease) 0.55s both}
.intro-divider{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;margin:clamp(10px,2vw,18px) 0 clamp(10px,2vw,16px);animation:fadeUp 1.5s var(--ease) 0.7s both}
.dl{width:clamp(26px,5vw,52px);height:1px;background:linear-gradient(90deg,transparent,rgba(170,105,228,0.4))}.dl.r{background:linear-gradient(270deg,transparent,rgba(170,105,228,0.4))}
.dstar{font-size:0.5rem;color:#a855f7;animation:sp 3s ease-in-out infinite}
@keyframes sp{0%,100%{opacity:0.4;text-shadow:0 0 5px #7c2fd4}50%{opacity:1;text-shadow:0 0 12px #7c2fd4,0 0 26px #5010a0}}
.intro-cta{font-family:'Raleway',sans-serif;font-weight:200;font-size:clamp(7px,1.2vmin,9px);letter-spacing:0.44em;margin-left:0.44em;color:rgba(170,105,228,0.38);text-transform:uppercase;animation:fadeUp 1.5s var(--ease) 0.9s both,blink 3.5s ease-in-out 2.5s infinite}
@keyframes blink{0%,100%{opacity:0.3}50%{opacity:0.75}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

#cur{position:fixed;top:0;left:0;width:8px;height:8px;border-radius:50%;background:var(--pp);pointer-events:none;z-index:99999;opacity:0;will-change:transform;transition:opacity .22s,width .15s,height .15s,background .15s,box-shadow .2s}
body.has-mouse #cur{opacity:1;box-shadow:0 0 7px 2px rgba(201,184,240,.32)}
body.has-mouse{cursor:none}
body.has-mouse *{cursor:none!important}
body.has-mouse.cbtn #cur{width:13px;height:13px;background:var(--pp2);box-shadow:0 0 12px 5px rgba(180,150,240,.55),0 0 26px 9px rgba(180,150,240,.22)}

#beam-c{position:fixed;inset:0;z-index:0;pointer-events:none;transition:opacity .35s ease}

#prog{position:fixed;top:0;left:0;z-index:1100;height:2px;width:0;background:linear-gradient(to right,var(--pp3),var(--pp));box-shadow:0 0 7px rgba(180,150,240,.45);transition:width .1s linear}

/* ── NAV ── slightly more compact, less pill-perfect */
#stop{position:fixed;bottom:2rem;right:1.6rem;z-index:1000;width:38px;height:38px;border-radius:10px;border:1px solid var(--b2);background:rgba(10,7,22,.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;color:var(--pp2);cursor:pointer;opacity:0;pointer-events:none;transition:opacity .30s ease,border-color .2s,box-shadow .2s}
#stop.show{opacity:1;pointer-events:all}
@media(hover:hover){#stop:hover{border-color:var(--pp);box-shadow:var(--g1)}}
#stop svg{width:16px;height:16px}

nav{position:fixed;z-index:10002;display:flex;align-items:center;justify-content:space-between;gap:1rem;transition:background .32s,border-color .32s,box-shadow .32s,opacity .30s,transform .35s ease}
@media(min-width:600px){
  nav{top:.9rem;left:50%;transform:translateX(-50%) translateY(0);width:min(calc(100vw - 2.4rem),860px);padding:.48rem .85rem .48rem 1rem;border-radius:14px;border:1px solid rgba(180,150,240,.12);background:rgba(4,4,8,.78);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 4px 28px rgba(0,0,0,.44)}
  nav.scrolled{background:rgba(4,4,8,.94);border-color:rgba(180,150,240,.20)}
  nav.nav-hidden{opacity:0;transform:translateX(-50%) translateY(-140%);pointer-events:none}
  .ham{display:none!important}
  .nav-links{display:flex!important}
  .nav-links a{font-size:.68rem;letter-spacing:.14em}
}
@media(max-width:599px){
  nav{top:0;left:0;right:0;width:100%;border-radius:0;padding:.68rem 1rem;border:none;border-bottom:1px solid rgba(180,150,240,.10);background:rgba(4,4,8,.20)!important;backdrop-filter:blur(30px) saturate(180%)!important;-webkit-backdrop-filter:blur(30px) saturate(180%)!important;box-shadow:none!important;justify-content:space-between;transform:none!important;opacity:1!important;pointer-events:all!important}
  nav.scrolled{border-bottom-color:rgba(180,150,240,.18)!important;background:rgba(4,4,8,.50)!important}
  .ham{display:flex!important}
  .nav-links{display:none!important}
  .nav-hire{display:none!important}
}
.nav-logo{display:flex;align-items:center;gap:.5rem;flex-shrink:0;font-family:'Syne',sans-serif;font-weight:800;font-size:.78rem;letter-spacing:.04em;color:var(--pp);text-decoration:none;transition:opacity .2s}
@media(hover:hover){.nav-logo:hover{opacity:.72}}
.nav-logo svg{width:20px;height:20px;flex-shrink:0}
.nav-links{display:flex;gap:.85rem;list-style:none;margin:0 auto;flex-shrink:1;min-width:0}
.nav-links a{color:var(--t3);text-decoration:none;font-size:.68rem;letter-spacing:.17em;text-transform:uppercase;line-height:1;position:relative;padding-bottom:3px;transition:color .2s}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--pp);transform:scaleX(0);transform-origin:left;transition:transform .24s ease}
@media(hover:hover){.nav-links a:hover{color:var(--pp2)}.nav-links a:hover::after{transform:scaleX(1)}}
.nav-links a.active{color:var(--pp2)}.nav-links a.active::after{transform:scaleX(1)}
.nav-hire{display:none;flex-shrink:0}
.ham{display:none;align-items:center;justify-content:center;flex-direction:column;gap:5px;width:36px;height:36px;border-radius:8px;border:1px solid var(--b1);background:rgba(180,150,240,.03);flex-shrink:0;cursor:pointer;transition:border-color .2s,background .2s;outline:none;-webkit-user-select:none;user-select:none}
@media(hover:hover){.ham:hover{border-color:var(--b2);background:rgba(180,150,240,.07)}}
.ham span{display:block;width:16px;height:1.5px;background:var(--pp);border-radius:2px;transform-origin:center;transition:transform .28s ease,opacity .2s,width .22s}
nav.open .ham span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
nav.open .ham span:nth-child(2){opacity:0;width:0}
nav.open .ham span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.mob-ov{position:fixed;inset:0;z-index:9999;background:rgba(3,2,10,.97);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;visibility:hidden;transition:opacity .30s,visibility .30s}
.mob-ov.open{opacity:1;pointer-events:all;visibility:visible}
.mob-list{list-style:none;display:flex;flex-direction:column;align-items:center;gap:0;width:100%;padding:0 2rem;margin-bottom:2rem}
.mob-list li{width:100%;opacity:0;transition:opacity .30s ease}
.mob-list li:nth-child(1){transition-delay:.04s}.mob-list li:nth-child(2){transition-delay:.08s}.mob-list li:nth-child(3){transition-delay:.12s}.mob-list li:nth-child(4){transition-delay:.16s}.mob-list li:nth-child(5){transition-delay:.20s}
.mob-ov.open .mob-list li{opacity:1}
.mob-list a{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.88rem 1rem;font-family:'Syne',sans-serif;font-weight:700;font-size:1.1rem;color:var(--t2);text-decoration:none;border-bottom:1px solid var(--b1);transition:color .18s,padding-left .18s}
.mob-list li:last-child a{border-bottom:none}
.mob-arr{opacity:0;transform:translateX(-4px);transition:opacity .18s,transform .18s;color:var(--pp3)}
@media(hover:hover){.mob-list a:hover{color:var(--pp);padding-left:1.3rem}.mob-list a:hover .mob-arr{opacity:1;transform:none}}
.mob-foot{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:0 2rem;opacity:0;transition:opacity .30s ease .18s}
.mob-ov.open .mob-foot{opacity:1}
.mob-socials{display:flex;gap:.5rem}
.mob-socials a{width:36px;height:36px;border-radius:50%;border:1px solid var(--b1);background:rgba(180,150,240,.03);display:flex;align-items:center;justify-content:center;color:var(--pp2);text-decoration:none;transition:border-color .18s,background .18s}
.mob-socials a:hover{border-color:var(--b2);background:rgba(180,150,240,.08)}

/* ── BUTTONS  -  two distinct personalities ── */
.btn{position:relative;display:inline-flex;align-items:center;gap:.40rem;padding:.60rem 1.25rem;font-family:'DM Sans',sans-serif;font-size:.70rem;font-weight:500;letter-spacing:.10em;text-transform:uppercase;line-height:1;color:var(--pp);background:transparent;border:1px solid var(--b2);border-radius:var(--r1);text-decoration:none;cursor:pointer;transition:color .26s,border-color .28s,background .28s,box-shadow .28s,transform .12s;-webkit-user-select:none;user-select:none;overflow:hidden}
.btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(180,150,240,.12),transparent);opacity:0;transition:opacity .28s}
@media(hover:hover){.btn:hover{color:#fff;border-color:var(--pp);background:rgba(180,150,240,.07);box-shadow:0 0 22px 7px rgba(180,150,240,.38),0 0 44px 12px rgba(140,100,220,.16)}.btn:hover::before{opacity:1}}
.btn:active{transform:scale(.96)}
.btn-sm{padding:.34rem .75rem;font-size:.64rem}
/* filled button  -  slightly warmer tint to differ from outline */
.btn-fill{background:rgba(110,32,174,.14);border-color:rgba(180,150,240,.30);box-shadow:none}
@media(hover:hover){.btn-fill:hover{background:rgba(130,90,210,.22);box-shadow:0 0 26px 8px rgba(180,150,240,.38)}}
.btn-icon{width:38px;height:38px;padding:0;justify-content:center;border-radius:9px;color:var(--pp2)}

.page{position:relative;z-index:1}
section{padding:clamp(3rem,7vw,5.5rem) clamp(1.1rem,5vw,3.5rem)}

/* ── DIVIDER  -  thinner, softer ── */
.divider{width:100%;height:1px;background:linear-gradient(to right,transparent,rgba(180,150,240,.10),transparent)}

/* ── SECTION LABELS  -  less perfectly uniform ── */
.sec-label{display:inline-flex;align-items:center;gap:.5rem;font-size:.65rem;letter-spacing:.20em;text-transform:uppercase;color:var(--pp3);line-height:1;margin-bottom:.5rem;font-family:'DM Sans',sans-serif}
.sec-label::before{content:'//';font-size:.58rem;color:var(--pp3);opacity:.5;letter-spacing:0;flex-shrink:0}
.sec-title{font-family:'Syne',sans-serif;font-weight:900;font-size:clamp(1.5rem,3.8vw,2.4rem);line-height:1.08;letter-spacing:-.03em;color:var(--t1);margin-bottom:1.2rem;word-break:break-word;overflow-wrap:break-word}

.r{opacity:0;transition:opacity .65s ease,transform .65s var(--ease)}
.r.v{opacity:1;transform:none}
.d1{transition-delay:.06s}.d2{transition-delay:.13s}.d3{transition-delay:.20s}.d4{transition-delay:.27s}.d5{transition-delay:.34s}.d6{transition-delay:.41s}

/* ── HERO  -  more asymmetric, less centered-template feel ── */
#home{min-height:100vh;min-height:100svh;display:flex;align-items:center;justify-content:flex-start;padding:clamp(4rem,10vw,5.5rem) clamp(1.1rem,5vw,3.5rem) clamp(2.5rem,6vw,3.5rem);position:relative;overflow:hidden}
.hero-inner{max-width:580px;width:100%;position:relative;z-index:1}
.hero-role{display:flex;align-items:center;gap:.6rem;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--pp2);line-height:1;margin-bottom:1.4rem;min-height:1.1em}
.hero-role::before{content:'';width:18px;height:1px;background:var(--pp2);flex-shrink:0}
.tw-cur{display:inline-block;width:2px;height:.78em;background:var(--pp2);vertical-align:text-bottom;margin-left:2px;animation:tblink .7s step-end infinite}
@keyframes tblink{0%,100%{opacity:1}50%{opacity:0}}
.hero-greeting{font-size:.68rem;color:var(--t4);letter-spacing:.06em;margin-bottom:.15rem;font-style:italic}
.hero-name{font-family:'Syne',sans-serif;font-weight:900;font-size:clamp(2rem,5.5vw,3.6rem);line-height:1.04;letter-spacing:-.035em;color:var(--t1);margin-bottom:1rem;word-break:break-word}
.hero-name .gr{display:block;background:linear-gradient(128deg,var(--pp) 0%,#e8daff 42%,var(--pp3) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;padding-bottom:.05em}
.hero-bio{font-size:.90rem;color:var(--t2);line-height:1.80;margin-bottom:2rem;max-width:470px}
.hero-bio em{color:var(--pp2);font-style:normal;font-weight:500}

/* stat boxes  -  uneven widths, not clone-stamped */
.hero-stats{display:flex;gap:.45rem;margin-bottom:2rem;flex-wrap:wrap}
.stat-box{border:1px solid var(--b1);border-radius:var(--r2);padding:.7rem .95rem;background:rgba(180,150,240,.010);min-width:78px;text-align:center;transition:border-color .22s,background .22s}
.stat-box:first-child{min-width:88px}
@media(hover:hover){.stat-box:hover{border-color:var(--b2);background:rgba(180,150,240,.035)}}
.stat-num{display:block;font-family:'Syne',sans-serif;font-weight:800;font-size:1.5rem;line-height:1;margin-bottom:.28rem;background:linear-gradient(135deg,var(--pp),var(--pp3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-lbl{display:block;font-size:.58rem;letter-spacing:.10em;text-transform:uppercase;color:var(--t4)}
.hero-btns{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}
60%{opacity:0;top:14px}61%{opacity:0;top:5px}100%{opacity:1;top:5px}}
.hero-orb{position:absolute;right:-8%;top:50%;transform:translateY(-50%);width:min(460px,52vw);height:min(460px,52vw);border-radius:50%;background:radial-gradient(ellipse at 38% 40%,rgba(120,72,220,.20) 0%,rgba(80,30,180,.10) 42%,transparent 70%);pointer-events:none;filter:blur(2px)}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(180,150,240,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(180,150,240,.025) 1px,transparent 1px);background-size:52px 52px;mask-image:radial-gradient(ellipse 65% 70% at 65% 50%,black 0%,transparent 100%);pointer-events:none}
.avail-badge{display:inline-flex;align-items:center;gap:.45rem;font-size:.60rem;letter-spacing:.12em;text-transform:uppercase;color:#4ade80;border:1px solid rgba(74,222,128,.18);border-radius:8px;padding:.28rem .72rem .28rem .54rem;background:rgba(74,222,128,.04);margin-bottom:1.25rem;width:fit-content;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.avail-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;flex-shrink:0;animation:avpulse 2s ease-in-out infinite}
@keyframes avpulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(74,222,128,.7),0 0 6px 1px rgba(74,222,128,.4)}50%{opacity:.75;box-shadow:0 0 0 5px rgba(74,222,128,0),0 0 10px 3px rgba(74,222,128,.55)}}

/* ── ABOUT ── */
#about{}
.about-header{margin-bottom:2.2rem}
.about-grid{display:grid;grid-template-columns:230px 1fr;gap:3rem;align-items:start}
.about-img-wrap{position:relative}
/* photo frame  -  slightly taller aspect, less perfect */
.about-frame{width:100%;aspect-ratio:4/5;border:1px solid var(--b2);border-radius:18px;overflow:hidden;background:var(--bg3);position:relative}
.about-frame::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(140,80,230,.18),transparent 65%);z-index:1;pointer-events:none}
.about-photo{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;position:absolute;inset:0;-webkit-user-drag:none;user-drag:none;-webkit-user-select:none;user-select:none;pointer-events:none}
.img-shield{position:absolute;inset:0;z-index:3;background:transparent;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:none}
.about-photo-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 38%,rgba(120,72,210,.18),rgba(8,4,22,.94) 70%)}
.exp-badge{position:absolute;bottom:0;left:0;right:0;padding:.65rem .9rem;background:rgba(6,4,18,.90);border-top:1px solid var(--b2);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:baseline;gap:.4rem;z-index:2}
.exp-num{font-family:'Syne',sans-serif;font-weight:800;font-size:1.45rem;background:linear-gradient(135deg,var(--pp),var(--pp3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.exp-lbl{font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--t3)}
.about-body{display:flex;flex-direction:column;gap:1.4rem}
.about-txt p{font-size:.85rem;color:var(--t2);line-height:1.82}
.about-txt p+p{margin-top:.85rem}
.about-txt strong{color:var(--pp2);font-weight:500}

/* info cards  -  slightly looser, not identical twins */
.info-cards{display:grid;grid-template-columns:1fr 1fr;gap:.32rem}
.info-card{display:flex;align-items:center;gap:.65rem;border:1px solid var(--b1);border-radius:12px;padding:.55rem .8rem;background:transparent;transition:border-color .20s,background .20s}
@media(hover:hover){.info-card:hover{border-color:var(--b2);background:rgba(180,150,240,.028)}}
.info-icon{width:28px;height:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border:1px solid var(--b1);border-radius:7px;background:rgba(180,150,240,.04)}
.info-icon svg{width:13px;height:13px;color:var(--pp3)}
.info-lbl{font-size:.56rem;letter-spacing:.10em;text-transform:uppercase;color:var(--t3);margin-bottom:.15rem}
.info-val{font-size:.76rem;color:var(--t2);font-weight:500}
.info-val a{color:var(--pp2);text-decoration:none;transition:color .2s}
@media(hover:hover){.info-val a:hover{color:var(--pp)}}
.about-actions{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}

/* ── SERVICES  -  cards with more visual variety ── */
#service{}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:.5rem}
/* each card gets a unique left accent line colour */
.svc-card{border:1px solid var(--b1);border-radius:18px;padding:1.5rem 1.35rem 1.35rem;background:transparent;transition:border-color .24s,background .24s,transform .24s;position:relative;overflow:hidden;border-left-width:2px}
.svc-card:nth-child(1){border-left-color:rgba(140,100,255,.35)}
.svc-card:nth-child(2){border-left-color:rgba(100,140,255,.30)}
.svc-card:nth-child(3){border-left-color:rgba(80,200,140,.28)}
.svc-card:nth-child(4){border-left-color:rgba(220,140,60,.28)}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(180,150,240,.35),transparent);opacity:0;transition:opacity .28s}
@media(hover:hover){.svc-card:hover{border-color:var(--b2);background:rgba(180,150,240,.022);transform:translateY(-2px)}.svc-card:hover::before{opacity:1}}
.svc-icon{width:40px;height:40px;border:1px solid var(--b1);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;background:rgba(180,150,240,.04)}
.svc-icon svg{width:19px;height:19px;color:var(--pp2)}
.svc-title{font-family:'Syne',sans-serif;font-weight:700;font-size:.92rem;color:var(--t1);margin-bottom:.5rem;letter-spacing:-.01em}
.svc-desc{font-size:.80rem;color:var(--t3);line-height:1.74}
/* dots replaced with a simple tag-line number */
.svc-dots{display:flex;gap:.28rem;margin-top:1rem}
.svc-dot{width:4px;height:4px;border-radius:50%;background:var(--pp3);opacity:.25}
.svc-dot:first-child{opacity:.9;width:14px;border-radius:999px}

/* ── PORTFOLIO ── */
#portfolio{}
.port-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.6rem}
.port-tabs{display:inline-flex;border:1px solid var(--b1);border-radius:10px;padding:3px;background:rgba(180,150,240,.010);position:relative;gap:3px}
.port-tab{font-size:.64rem;letter-spacing:.13em;text-transform:uppercase;color:var(--t3);padding:.48rem .85rem;border-radius:8px;cursor:pointer;border:none;background:transparent;transition:color .22s;position:relative;z-index:1;-webkit-user-select:none;user-select:none}
.port-tab.active{color:var(--t1)}
#tab-ink{position:absolute;top:3px;bottom:3px;border-radius:7px;background:rgba(180,150,240,.11);border:1px solid var(--b2);transition:transform .28s var(--ease),width .28s var(--ease)}
@media(hover:hover){.port-tab:hover:not(.active){color:var(--t2)}}
.port-sub{max-width:460px;font-size:.82rem;color:var(--t3);line-height:1.70;margin-bottom:1.6rem}
.tab-panel{transition:opacity .30s ease,transform .30s var(--ease);opacity:1;transform:none;pointer-events:all}
.tab-panel.hidden{opacity:0;pointer-events:none;position:absolute;visibility:hidden}
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(275px,1fr));gap:.5rem}
.proj-card{border:1px solid var(--b1);border-radius:18px;overflow:hidden;background:transparent;cursor:pointer;opacity:0;transition:opacity .55s ease,border-color .24s,box-shadow .24s,transform .24s}
.proj-card.visible{opacity:1}
@media(hover:hover){.proj-card.visible:hover{border-color:var(--b2);box-shadow:var(--g1);transform:translateY(-3px)}.proj-card.visible:hover .proj-ov{opacity:1}.proj-card.visible:hover .proj-thumb-img{transform:scale(1.04)}}
.proj-thumb{position:relative;aspect-ratio:16/10;overflow:hidden}
.proj-thumb-bg{position:absolute;inset:0}
.proj-thumb-img{position:absolute;inset:0;transition:transform .44s var(--ease)}
.proj-thumb-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(200,180,240,.55)}
.proj-thumb-icon svg{width:52px;height:52px;stroke-width:1}
.proj-ov{position:absolute;inset:0;background:rgba(10,6,25,.55);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .26s}
.proj-expand{width:34px;height:34px;border:1px solid rgba(200,180,240,.5);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff}
.proj-expand svg{width:14px;height:14px}
.proj-body{padding:.8rem .95rem .95rem}
.proj-tag{font-size:.56rem;letter-spacing:.12em;text-transform:uppercase;color:var(--pp3);margin-bottom:.3rem}
.proj-title{font-family:'Syne',sans-serif;font-weight:700;font-size:.88rem;color:var(--t1);margin-bottom:.34rem;letter-spacing:-.01em}
.proj-desc{font-size:.74rem;color:var(--t3);line-height:1.62}
.tech-grid-wrap{display:flex;flex-direction:column;gap:.5rem}
.tech-section-label{font-size:.60rem;letter-spacing:.18em;text-transform:uppercase;color:var(--t4);margin-bottom:.1rem}
.tech-grid-langs,.tech-grid-apps{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:.34rem}
.tech-card{border:1px solid var(--b1);border-radius:12px;padding:.95rem .5rem .82rem;background:transparent;display:flex;flex-direction:column;align-items:center;gap:.45rem;opacity:0;transition:opacity .55s ease,border-color .20s,background .20s}
.tech-card.visible{opacity:1}
@media(hover:hover){.tech-card:hover{border-color:var(--b2);background:rgba(180,150,240,.028)}}
.tech-icon{width:30px;height:30px;display:flex;align-items:center;justify-content:center}
.tech-icon svg{width:30px;height:30px}
.tech-name{font-size:.56rem;letter-spacing:.07em;text-transform:uppercase;color:var(--t3);text-align:center}

/* ── LIGHTBOX ── */
#lb{position:fixed;inset:0;z-index:99000;background:rgba(2,1,8,.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .32s ease}
#lb.on{opacity:1;pointer-events:all}
#lb.on .lb-panel{opacity:1}
.lb-panel{max-width:500px;width:100%;border:1px solid var(--b2);border-radius:20px;background:var(--bg3);padding:1.7rem 1.8rem;position:relative;opacity:0;transition:opacity .32s ease .05s}
.lb-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.lb-title{font-family:'Syne',sans-serif;font-weight:800;font-size:1.15rem;color:var(--t1);letter-spacing:-.02em}
.lb-x{width:30px;height:30px;border:1px solid var(--b1);border-radius:8px;background:rgba(180,150,240,.04);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t3);flex-shrink:0;transition:border-color .18s,color .18s}
@media(hover:hover){.lb-x:hover{border-color:var(--b2);color:var(--t1)}}
.lb-x svg{width:14px;height:14px}
.lb-desc{font-size:.82rem;color:var(--t2);line-height:1.78;margin-bottom:1.2rem}
.lb-chips{display:flex;flex-wrap:wrap;gap:.30rem;margin-bottom:1.3rem}
.lb-chip{font-size:.58rem;letter-spacing:.10em;text-transform:uppercase;color:var(--pp2);border:1px solid var(--b2);border-radius:6px;padding:.20rem .62rem;background:rgba(180,150,240,.04)}
.lb-nav{display:flex;gap:.5rem;justify-content:flex-end}

/* ── CONTACT ── */
#contact{padding:5rem 3.5rem 5.5rem}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:1.4rem}
.contact-intro{font-size:.84rem;color:var(--t2);line-height:1.82}
.contact-items{display:flex;flex-direction:column;gap:.34rem}
.contact-item{display:flex;align-items:center;gap:.65rem;padding:.58rem .8rem;border:1px solid var(--b1);border-radius:11px;background:transparent;transition:border-color .20s,background .20s}
@media(hover:hover){.contact-item:hover{border-color:var(--b2);background:rgba(180,150,240,.025)}}
.contact-item-icon{width:30px;height:30px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border:1px solid var(--b1);border-radius:7px;background:rgba(180,150,240,.04)}
.contact-item-icon svg{width:14px;height:14px;color:var(--pp3)}
.contact-item-lbl{font-size:.56rem;letter-spacing:.10em;text-transform:uppercase;color:var(--t3);margin-bottom:.12rem}
.contact-item-val{font-size:.76rem;color:var(--t2);font-weight:500}
.contact-item-val a{color:var(--pp2);text-decoration:none;transition:color .2s}
@media(hover:hover){.contact-item-val a:hover{color:var(--pp)}}
.contact-btns{display:flex;gap:.5rem;flex-wrap:wrap}
.contact-form{display:flex;flex-direction:column;gap:.6rem}
.field-label{font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--t3);margin-bottom:.26rem;display:block}
.field-input,.field-textarea{width:100%;background:rgba(180,150,240,.018);border:1px solid var(--b1);border-radius:10px;padding:.72rem .95rem;color:var(--t1);font-family:'DM Sans',sans-serif;font-size:.82rem;line-height:1.6;outline:none;resize:none;transition:border-color .22s,box-shadow .22s,background .22s;-webkit-appearance:none}
.field-input:focus,.field-textarea:focus{border-color:var(--pp3);background:rgba(180,150,240,.038);box-shadow:0 0 0 3px rgba(140,80,220,.12)}
.field-textarea{min-height:108px}
.field-group{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.form-submit{align-self:flex-start}

/* ── FOOTER ── */
footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 3.5rem;border-top:1px solid var(--b1);font-size:.63rem;letter-spacing:.07em;color:var(--t4);flex-wrap:wrap}
.foot-copy{opacity:.6}
.foot-links{display:flex;gap:1rem}
.foot-links a{color:var(--t4);text-decoration:none;transition:color .2s}
@media(hover:hover){.foot-links a:hover{color:var(--pp2)}}

#grain{position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.028}
#grain canvas{position:absolute;inset:0;width:100%;height:100%}

/* ── TIMELINE ── */
#timeline{padding:5rem 3.5rem}
.tl-wrap{position:relative;max-width:660px;margin:0 auto;padding-left:2.2rem}
.tl-wrap::before{content:'';position:absolute;left:0;top:.5rem;bottom:.5rem;width:1px;background:linear-gradient(to bottom,transparent,var(--b2) 8%,var(--b2) 92%,transparent)}
.tl-item{position:relative;margin-bottom:2.2rem}
.tl-item:last-child{margin-bottom:0}
.tl-dot{position:absolute;left:-2.2rem;top:.44rem;width:8px;height:8px;border-radius:50%;background:var(--pp3);border:2px solid var(--bg);box-shadow:0 0 0 2px var(--pp3),0 0 8px 1px rgba(140,80,220,.30);transform:translateX(-3.5px)}
.tl-year{font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--pp3);margin-bottom:.24rem;line-height:1}
.tl-title{font-family:'Syne',sans-serif;font-weight:700;font-size:.93rem;color:var(--t1);margin-bottom:.28rem;letter-spacing:-.01em}
.tl-desc{font-size:.81rem;color:var(--t2);line-height:1.78}
.tl-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.56rem;letter-spacing:.10em;text-transform:uppercase;color:var(--pp2);border:1px solid var(--b1);border-radius:6px;padding:.16rem .55rem;background:transparent;margin-top:.5rem}

/* ── TESTIMONIALS ── */
#testimonials{overflow:hidden}
.tst-carousel-wrap{position:relative;margin-top:1.8rem}
.tst-track-outer{overflow:hidden;border-radius:18px}
.tst-track{display:flex;gap:.65rem;transition:transform .48s var(--ease);will-change:transform}
.tst-card{border:1px solid var(--b1);border-radius:18px;padding:1.45rem 1.35rem 1.25rem;background:transparent;position:relative;overflow:hidden;transition:border-color .24s,background .24s,opacity .55s ease;flex:0 0 calc(33.333% - .43rem);min-width:280px;opacity:0}
.tst-card.visible{opacity:1}
.tst-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(180,150,240,.30),transparent);opacity:0;transition:opacity .28s}
@media(hover:hover){.tst-card:hover{border-color:var(--b2);background:rgba(180,150,240,.018)}.tst-card:hover::before{opacity:1}}
.tst-nav{display:flex;align-items:center;justify-content:space-between;margin-top:1rem}
.tst-dots{display:flex;gap:.40rem;align-items:center}
.tst-dot{width:5px;height:5px;border-radius:50%;background:var(--b2);border:none;cursor:pointer;padding:0;transition:background .22s,transform .22s,width .22s}
.tst-dot.active{background:var(--pp2);width:16px;border-radius:999px}
@media(hover:hover){.tst-dot:not(.active):hover{background:var(--pp3)}}
.tst-arrows{display:flex;gap:.4rem}
.tst-arr{width:32px;height:32px;border-radius:8px;border:1px solid var(--b1);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--t2);transition:border-color .2s,background .2s,color .2s;padding:0}
.tst-arr:disabled{opacity:.3;cursor:not-allowed}
@media(hover:hover){.tst-arr:not(:disabled):hover{border-color:var(--b2);background:rgba(180,150,240,.10);color:var(--t1)}}
.tst-skeleton{border:1px solid var(--b1);border-radius:18px;padding:1.45rem 1.35rem 1.25rem;background:transparent;min-height:175px;flex:0 0 calc(33.333% - .43rem);min-width:280px;position:relative;overflow:hidden}
.tst-skeleton::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 25%,rgba(180,150,240,.06) 50%,transparent 75%);animation:skelwave 1.4s ease-in-out infinite;background-size:200% 100%}
@keyframes skelwave{0%{background-position:200% 0}100%{background-position:-200% 0}}
.tst-quote{font-size:2.2rem;line-height:1;color:var(--pp3);opacity:.28;font-family:'Syne',sans-serif;margin-bottom:.45rem;user-select:none}
.tst-text{font-size:.82rem;color:var(--t2);line-height:1.80;margin-bottom:1.1rem;font-style:italic}
.tst-author{display:flex;align-items:center;gap:.65rem}
.tst-avatar{width:32px;height:32px;border-radius:50%;border:1px solid var(--b2);background:rgba(180,150,240,.06);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:'Syne',sans-serif;font-weight:700;font-size:.68rem;color:var(--pp)}
.tst-name{font-family:'Syne',sans-serif;font-weight:700;font-size:.78rem;color:var(--t1);letter-spacing:-.01em}
.tst-role{font-size:.63rem;color:var(--t3);margin-top:.06rem}
.tst-stars{display:flex;gap:.16rem;margin-bottom:.8rem}
.tst-star{width:11px;height:11px;color:#f59e0b}
@media(max-width:768px){.tst-card,.tst-skeleton{flex:0 0 calc(50% - .33rem)}}
@media(max-width:520px){.tst-card,.tst-skeleton{flex:0 0 calc(85% - .33rem);min-width:0}}

/* ── TOAST ── */
#toast{position:fixed;bottom:5.5rem;left:50%;transform:translateX(-50%) translateY(16px);z-index:99999;display:flex;align-items:center;gap:.6rem;padding:.62rem 1rem;border-radius:9px;border:1px solid var(--b2);background:rgba(10,7,22,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);font-size:.74rem;color:var(--t1);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .28s ease,transform .28s var(--ease)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:none}
#toast svg{flex-shrink:0;color:var(--pp2)}

/* ── RESPONSIVE ── */
@media(min-width:1200px){
  section{padding:6rem 5rem}
  #home{padding:6rem 5rem 4rem}
  #contact{padding:6rem 5rem 6.5rem}
  #timeline{padding:6rem 5rem}
}
@media(min-width:900px) and (max-width:1199px){
  section{padding:4.5rem 3rem}
  #home{padding:5rem 3rem 3.5rem}
  .about-grid{grid-template-columns:200px 1fr;gap:2.4rem}
}
@media(min-width:600px) and (max-width:899px){
  section{padding:3.5rem 2rem}
  #home{padding:5rem 2rem 3rem;align-items:flex-start}
  .about-grid{grid-template-columns:1fr;gap:1.8rem}
  .about-img-wrap{max-width:210px}
  .info-cards{grid-template-columns:1fr 1fr}
  .proj-grid{grid-template-columns:repeat(2,1fr)}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .field-group{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .hero-orb{display:none}
  .foot-links{display:none}
  footer{flex-direction:column;text-align:center;padding:.75rem 1rem;gap:.2rem}
  #contact{padding:3.5rem 2rem 4rem}
  #timeline{padding:3.5rem 2rem}
}
@media(max-width:1000px){.contact-grid{grid-template-columns:1fr;gap:2rem}}
@media(max-width:599px){
  section{padding:2.8rem 1.1rem}
  #home{min-height:100svh;min-height:100vh;align-items:flex-start;padding-top:5rem;padding-left:1.1rem;padding-right:1.1rem;padding-bottom:2.5rem}
  .about-grid{grid-template-columns:1fr;gap:1.5rem}
  .about-img-wrap{max-width:190px}
  .info-cards{grid-template-columns:1fr 1fr}
  .proj-grid{grid-template-columns:repeat(2,1fr)}
  .svc-grid{grid-template-columns:1fr}
  footer{flex-direction:column;text-align:center;padding:.75rem 1rem;gap:.2rem}
  .foot-links{display:none}
  .hero-orb{display:none}
  .field-group{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  #timeline{padding:2.8rem 1.1rem}
  .tl-wrap{padding-left:1.8rem}
  .tl-dot{left:-1.8rem}
  #contact{padding:2.8rem 1.1rem 3rem}
}
@media(max-width:480px){
  section{padding:2.4rem 1rem}
  #home{padding-top:4.8rem;padding-bottom:2rem}
  .hero-name{font-size:1.55rem;word-break:break-word}
  .proj-grid{grid-template-columns:repeat(2,1fr);gap:.3rem}
  .tech-grid-langs,.tech-grid-apps{grid-template-columns:repeat(3,1fr)}
  .proj-desc{display:none}
  .lb-panel{padding:1.2rem 1rem}
  .info-cards{grid-template-columns:1fr}
  .port-tabs{width:100%;display:flex}
  .port-tab{flex:1;padding:.46rem .38rem;font-size:.57rem}
  .proj-tag{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .proj-title{word-break:break-word;overflow-wrap:break-word}
  .intro-name{letter-spacing:0.28em;margin-left:0.28em}
  .intro-sub{letter-spacing:0.18em;margin-left:0.18em}
  .kt-text{font-size:clamp(72px,18vmin,150px)}
  .hero-stats{gap:.32rem}
  .stat-box{padding:.55rem .7rem;min-width:70px}
  .hero-btns{gap:.42rem}
  .tl-wrap{padding-left:1.6rem}
  .tst-card,.tst-skeleton{flex:0 0 calc(88% - .33rem);min-width:0}
}
@media(max-width:360px){
  section{padding:2rem .9rem}
  #home{padding-top:4.5rem}
  .hero-name{font-size:1.28rem}
  .proj-grid{grid-template-columns:repeat(2,1fr);gap:.25rem}
  .kt-text{font-size:clamp(58px,17vmin,120px)}
  .intro-name{letter-spacing:0.16em;margin-left:0.16em}
  .stat-box{min-width:62px;padding:.48rem .58rem}
}

/* ── DIARY / MAICA / FRANCINE overlays (unchanged logic, minor radius tweak) ── */
.skills-wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem 1.8rem;margin-top:.4rem}
@media(max-width:768px){.skills-wrap{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.skills-wrap{grid-template-columns:1fr}}
.skills-group-label{font-size:.60rem;letter-spacing:.20em;text-transform:uppercase;color:var(--pp3);margin-bottom:.75rem;display:flex;align-items:center;gap:.45rem}
.skills-group-label::after{content:'';flex:1;height:1px;background:var(--b1)}
.skill-item{margin-bottom:.7rem}
.skill-item:last-child{margin-bottom:0}
.skill-top{margin-bottom:.35rem}
.skill-name{font-size:.75rem;color:var(--t2);font-weight:500}
.skill-track{height:4px;background:var(--b1);border-radius:999px;overflow:hidden}
.skill-bar{height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--pp3),var(--pp));transition:width 1.1s cubic-bezier(.22,1,.36,1)}

@media(max-width:599px){.s{display:none}#grain{display:none}}
@keyframes avpulse-red{
  0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(248,113,113,.7),0 0 6px 1px rgba(248,113,113,.4)}
  50%{opacity:.75;box-shadow:0 0 0 5px rgba(248,113,113,0),0 0 10px 3px rgba(248,113,113,.55)}
}
