:root{
  --bg:#100e09;--bg2:#151209;--bg3:#1a160c;--surf:#211c12;--surf2:#2c2518;
  --b0:rgba(220,185,80,.07);--b1:rgba(220,185,80,.18);--b2:rgba(220,185,80,.32);
  --gold:#e8c040;--gold2:#f5d060;--blue:#1c3f7a;--blue2:#2a57a8;--bluel:#5880c0;
  --t1:#ede5ce;--t2:#7a7060;--t3:#443c2c;
  --FC:"Barlow Condensed",sans-serif;--FB:"Barlow",sans-serif;--FM:"DM Mono",monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--t1);font-family:var(--FB);overflow-x:hidden;cursor:auto;}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:998;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23f)' opacity='.055'/%3E%3C/svg%3E");
  opacity:.85;}

/* ── CURSOR ── */
.cr{width:8px;height:8px;background:var(--gold);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:exclusion;}
.crr{width:36px;height:36px;border:1px solid rgba(232,192,64,.5);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .18s,height .18s,border-color .18s;}

/* ══ STAR WARS INTRO ══ */
#sw{position:fixed;inset:0;background:#000;z-index:2000;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;transition:opacity 1.2s;}
#sw.gone{opacity:0;pointer-events:none;}
#sw canvas{position:absolute;inset:0;width:100%;height:100%;}
.sw-logo{position:relative;z-index:2;text-align:center;margin-bottom:40px;animation:swFade 3s ease forwards;}
.sw-logo h2{font-family:var(--FC);font-style:italic;font-weight:900;font-size:clamp(22px,4vw,44px);letter-spacing:.2em;text-transform:uppercase;color:var(--gold);}
.sw-logo p{font-family:var(--FM);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:rgba(232,192,64,.6);margin-top:6px;}
@keyframes swFade{0%{opacity:1}80%{opacity:1}100%{opacity:0}}
.sw-crawl-outer{position:relative;z-index:2;width:min(600px,86vw);perspective:280px;height:54vh;overflow:hidden;}
.sw-crawl-outer::after{content:"";position:absolute;top:0;left:0;right:0;height:28%;background:linear-gradient(#000,transparent);z-index:3;}
.sw-crawl{transform-origin:50% 100%;transform:rotateX(18deg);animation:crawl 24s linear 2.4s forwards;padding:0 8px;}
@keyframes crawl{from{transform:rotateX(18deg) translateY(105%)}to{transform:rotateX(18deg) translateY(-230%)}}
.sw-crawl p{font-family:var(--FC);font-style:italic;font-weight:700;font-size:clamp(14px,2.1vw,21px);letter-spacing:.07em;text-transform:uppercase;color:var(--gold);line-height:1.6;text-align:center;margin-bottom:18px;}
.sw-crawl .title{font-size:clamp(20px,3.2vw,32px);font-weight:900;color:var(--gold2);margin-bottom:26px;}
.sw-skip{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:4;font-family:var(--FM);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(232,192,64,.45);cursor:auto;border:1px solid rgba(232,192,64,.22);padding:7px 18px;background:transparent;transition:color .2s,border-color .2s;animation:fadeIn .8s 1.5s both;}
.sw-skip:hover{color:var(--gold);border-color:var(--gold);}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ── LANG ── */
.lsw{position:fixed;top:20px;right:48px;z-index:600;display:flex;gap:1px;background:rgba(16,14,9,.9);border:1px solid var(--b2);padding:3px;backdrop-filter:blur(14px);}
.lb{font-family:var(--FM);font-size:10px;letter-spacing:.17em;text-transform:uppercase;color:var(--t2);background:transparent;border:none;padding:6px 12px;cursor:auto;transition:color .2s,background .2s;}
.lb.on{background:var(--gold);color:#100e09;font-weight:500;}
.lb:hover:not(.on){color:var(--t1);}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:500;padding:22px 48px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid transparent;transition:background .3s,border-color .3s;}
nav.sc{background:rgba(16,14,9,.94);backdrop-filter:blur(20px);border-color:var(--b0);}
.nl{font-family:var(--FC);font-size:20px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:var(--t1);text-decoration:none;}
.nl span{color:var(--gold);}
.nls{display:flex;gap:24px;list-style:none;}
.nls a{font-family:var(--FM);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--t2);text-decoration:none;transition:color .2s;}
.nls a:hover{color:var(--gold);}

/* ══════════════ HERO ══════════════ */
#hero{min-height:100vh;display:flex;align-items:center;padding:100px 48px 64px;position:relative;overflow:hidden;}
#starCanvas{position:absolute;inset:0;width:100%;height:100%;}
.hvign{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to right,rgba(16,14,9,.85) 0%,rgba(16,14,9,.4) 55%,rgba(16,14,9,.6) 100%),
  radial-gradient(ellipse 80% 60% at 50% 0%,rgba(200,140,0,.04) 0%,transparent 60%);}
.hstripe{position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,transparent,var(--blue2) 40%,transparent);}
.hwm{position:absolute;right:-60px;top:50%;transform:translateY(-52%);font-family:var(--FC);font-style:italic;font-weight:900;font-size:min(660px,55vw);line-height:1;color:rgba(232,192,64,.014);pointer-events:none;user-select:none;}

/* HERO GRID — name left, photo right, both vertically centred */
.hero-g{position:relative;z-index:2;display:grid;grid-template-columns:1fr 380px;gap:56px;align-items:center;width:100%;padding:100px 0 64px;}
.hero-left{}
.obadge{display:inline-flex;align-items:center;gap:8px;font-family:var(--FM);font-size:10px;letter-spacing:.15em;color:var(--t2);background:rgba(232,192,64,.07);border:1px solid var(--b1);padding:5px 14px;border-radius:2px;margin-bottom:20px;}
.odot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.6)}}
.hey{font-family:var(--FM);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;display:flex;align-items:center;gap:12px;}
.hey::before{content:"";width:28px;height:1px;background:var(--gold);}
.hname{font-family:var(--FC);font-style:italic;font-weight:900;font-size:clamp(72px,9.5vw,160px);line-height:.88;letter-spacing:-.01em;text-transform:uppercase;}
.hname .n1{display:block;color:var(--t1);}
.hname .n2{display:block;color:var(--gold);}
.hrule{height:3px;margin:22px 0;background:linear-gradient(90deg,var(--gold),var(--gold2),transparent);}
.hbio{font-size:15px;line-height:1.75;color:var(--t2);max-width:480px;font-weight:300;margin-bottom:22px;}
.hbio strong{color:var(--t1);font-weight:500;}
.hstats{display:flex;gap:28px;margin-bottom:24px;}
.stn{font-family:var(--FC);font-size:46px;font-weight:900;font-style:italic;line-height:1;color:var(--gold);}
.stl{font-family:var(--FM);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--t3);margin-top:2px;}
.hbtns{display:flex;gap:10px;flex-wrap:wrap;}
.bg{font-family:var(--FC);font-size:15px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;background:var(--gold);color:#100e09;padding:11px 26px;border:none;border-radius:1px;text-decoration:none;cursor:auto;transition:transform .18s,box-shadow .18s;}
.bg:hover{transform:translateY(-2px);box-shadow:0 6px 28px rgba(232,192,64,.28);}
.bo{font-family:var(--FC);font-size:15px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:transparent;color:var(--t2);padding:10px 22px;border:1px solid var(--b2);border-radius:1px;text-decoration:none;cursor:auto;transition:color .2s,border-color .2s;}
.bo:hover{color:var(--gold);border-color:rgba(232,192,64,.45);}

/* PHOTO — right column, centred with the text block */
.hero-photo{display:flex;justify-content:flex-end;align-items:center;height:100%;}
.photo-frame{position:relative;width:300px;}
.photo-frame img{width:100%;height:420px;object-fit:cover;object-position:center 15%;display:block;filter:grayscale(10%) contrast(1.04);}
/* gold border offset */
.photo-frame::before{content:"";position:absolute;top:-8px;left:-8px;right:-8px;bottom:-8px;border:2px solid var(--gold);z-index:-1;}
.photo-frame::after{display:none;}
.photo-tag{position:absolute;bottom:14px;left:-18px;background:var(--gold);color:#100e09;font-family:var(--FC);font-style:italic;font-weight:900;font-size:15px;letter-spacing:.06em;text-transform:uppercase;padding:7px 15px;z-index:2;}
.photo-city{position:absolute;top:14px;right:-10px;background:var(--blue2);color:#fff;font-family:var(--FM);font-size:9px;letter-spacing:.17em;text-transform:uppercase;padding:5px 9px;writing-mode:vertical-rl;}

/* ══ SECTION HEADERS ══ */
.shdr{display:flex;align-items:baseline;gap:18px;margin-bottom:52px;}
.snum{font-family:var(--FM);font-size:10px;color:var(--gold);letter-spacing:.22em;}
.stit{font-family:var(--FC);font-style:italic;font-size:clamp(40px,5.5vw,76px);font-weight:900;letter-spacing:.01em;text-transform:uppercase;line-height:.95;color:var(--t1);}
.slin{flex:1;height:1px;background:var(--b0);}

/* ══ ABOUT ══ */
#about{padding:120px 48px;background:var(--bg2);}
.about-g{display:grid;grid-template-columns:1.15fr 1fr;gap:72px;align-items:start;}
.abp{font-size:15px;line-height:1.8;color:var(--t2);margin-bottom:16px;font-weight:300;}
.abp strong{color:var(--t1);font-weight:500;}
.cbq{font-family:var(--FC);font-style:italic;font-weight:900;font-size:clamp(19px,2.3vw,29px);letter-spacing:.01em;text-transform:uppercase;line-height:1.05;color:var(--gold);border-left:3px solid var(--gold);padding:13px 17px;background:rgba(232,192,64,.04);margin:26px 0;}
.abtags{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;}
.abt{font-family:var(--FM);font-size:10px;letter-spacing:.11em;color:var(--t3);background:var(--surf);border:1px solid var(--b0);padding:4px 10px;border-radius:1px;}
.abt.kw-tag{color:var(--gold);border-color:rgba(232,192,64,.28);background:rgba(232,192,64,.05);transition:box-shadow .3s,border-color .3s,color .2s;cursor:default;}
.abt.kw-tag:hover{color:var(--gold2);border-color:rgba(232,192,64,.55);box-shadow:0 0 12px rgba(232,192,64,.18);}
/* right column cards */
.ic{background:var(--surf);border:1px solid var(--b0);border-radius:1px;padding:24px;margin-bottom:10px;}
.icl{font-family:var(--FM);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:13px;padding-bottom:9px;border-bottom:1px solid var(--b0);}
.edu-nm{font-family:var(--FC);font-size:15px;font-weight:800;letter-spacing:.02em;text-transform:uppercase;color:var(--t1);margin-bottom:3px;}
.edu-s{font-family:var(--FM);font-size:11px;color:var(--t2);line-height:1.6;}
.edu-hl{color:var(--gold);}
.aw-r{display:flex;gap:12px;align-items:flex-start;margin-bottom:11px;}
.aw-i{width:30px;height:30px;border-radius:1px;background:rgba(232,192,64,.07);border:1px solid var(--b1);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
.aw-nm{font-family:var(--FC);font-size:13px;font-weight:800;color:var(--t1);text-transform:uppercase;letter-spacing:.02em;margin-bottom:1px;}
.aw-d{font-family:var(--FM);font-size:10px;color:var(--t2);line-height:1.5;}

/* ══ SKILLS ══ */
#skills{padding:120px 48px;background:var(--bg);}
.skw{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--b0);border:1px solid var(--b0);border-radius:1px;overflow:hidden;}
.skc{background:var(--bg2);padding:24px 20px;}
.skh{font-family:var(--FC);font-style:italic;font-size:18px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;padding-bottom:9px;border-bottom:1px solid var(--b0);}
.ski{display:flex;align-items:center;gap:8px;font-family:var(--FC);font-size:15px;font-weight:600;letter-spacing:.02em;color:var(--t2);padding:3px 0;transition:color .2s;}
.ski::before{content:"";width:3px;height:3px;border-radius:50%;background:var(--surf2);flex-shrink:0;transition:background .2s;}
.ski:hover{color:var(--t1);}.ski:hover::before{background:var(--gold);}

/* ══ PROJECTS ══ */
#projects{padding:120px 48px;background:var(--bg2);}
/* Statify featured */
.feat{background:var(--bg3);border:1px solid var(--b0);border-radius:1px;padding:44px;display:grid;grid-template-columns:1.1fr 1fr;gap:44px;align-items:center;position:relative;overflow:hidden;margin-bottom:2px;transition:border-color .3s;}
.feat:hover{border-color:var(--b2);}
.feat::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold2),transparent);}
.feat::after{content:"";position:absolute;top:0;right:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--blue2),transparent);}
.fwm{position:absolute;right:-20px;bottom:-48px;font-family:var(--FC);font-style:italic;font-weight:900;font-size:220px;line-height:1;color:rgba(232,192,64,.022);pointer-events:none;user-select:none;}
.pey{font-family:var(--FM);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.pnam{font-family:var(--FC);font-style:italic;font-weight:900;font-size:clamp(44px,5.5vw,70px);letter-spacing:-.01em;text-transform:uppercase;line-height:.9;margin-bottom:12px;color:var(--t1);}
.pdsc{font-size:14px;line-height:1.75;color:var(--t2);margin-bottom:16px;font-weight:300;}
.ppls{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:18px;}
.ppl{font-family:var(--FM);font-size:10px;letter-spacing:.06em;color:var(--t3);background:var(--surf);border:1px solid var(--b0);padding:4px 9px;border-radius:1px;}
.plks{display:flex;gap:14px;}
.plk{font-family:var(--FM);font-size:11px;letter-spacing:.06em;text-decoration:none;color:var(--t2);transition:color .2s;border-bottom:1px solid transparent;padding-bottom:2px;}
.plk:hover{color:var(--gold);border-color:var(--gold);}
.plkg{color:var(--gold);border-color:rgba(232,192,64,.35);}
/* phone mockup */
.phone-wrap{display:flex;justify-content:center;align-items:center;gap:20px;}
.phone{position:relative;width:155px;flex-shrink:0;}
.phone-body{background:#0a0a0a;border-radius:26px;border:2px solid #333;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.55),inset 0 0 0 1px rgba(255,255,255,.06);}
.phone-body img{width:100%;display:block;}
.phone-notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:56px;height:13px;background:#0a0a0a;border-radius:0 0 9px 9px;z-index:2;}
.si-wrap{display:flex;flex-direction:column;align-items:center;gap:7px;}
.si-img{width:60px;height:60px;border-radius:13px;overflow:hidden;box-shadow:0 4px 18px rgba(0,0,0,.4);}
.si-img img{width:100%;height:100%;object-fit:cover;}
.si-lbl{font-family:var(--FM);font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--t3);}
/* project grid */
.pg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--b0);border:1px solid var(--b0);border-radius:1px;overflow:hidden;}
.pc{background:var(--bg3);padding:26px;transition:background .25s;position:relative;overflow:hidden;}
.pc:hover{background:var(--surf);}
.pc::before{content:"";position:absolute;top:0;left:0;right:0;height:0;background:var(--blue2);transition:height .22s;}
.pc:hover::before{height:2px;}
.pc-n{font-family:var(--FM);font-size:10px;letter-spacing:.17em;color:var(--t3);margin-bottom:11px;}
.pc-nm{font-family:var(--FC);font-style:italic;font-size:21px;font-weight:900;text-transform:uppercase;margin-bottom:8px;line-height:1;color:var(--t1);}
.pc-d{font-size:13px;line-height:1.7;color:var(--t2);margin-bottom:14px;font-weight:300;}
.pc-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:13px;}
.tx{font-family:var(--FM);font-size:10px;color:var(--t3);background:rgba(232,192,64,.04);padding:3px 7px;border-radius:1px;}
.pc-lk{font-family:var(--FM);font-size:10px;color:var(--t3);text-decoration:none;letter-spacing:.1em;transition:color .2s;}
.pc-lk:hover{color:var(--gold);}

/* ══ EVENTS ══ */
#events{padding:120px 48px;background:var(--bg);}
/* Two event cards stacked vertically, each with its own photos */
.ev-card{background:var(--bg2);border:1px solid var(--b0);border-radius:1px;overflow:hidden;margin-bottom:2px;transition:border-color .3s;}
.ev-card:hover{border-color:var(--b1);}
/* top image strip */
.ev-img-strip{display:grid;height:280px;overflow:hidden;}
.ev-img-strip.two{grid-template-columns:1fr 1fr;}
.ev-img-strip.three{grid-template-columns:1fr 1fr 1fr;}
.ev-img-slot{overflow:hidden;position:relative;height:280px;}
.ev-img-slot img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:grayscale(12%) contrast(1.04);transition:transform .5s;display:block;}
.ev-card:hover .ev-img-slot img{transform:scale(1.04);}
/* gold line top */
.ev-img-strip::before{content:"";display:none;}
.ev-card::before{content:"";display:block;height:3px;background:linear-gradient(90deg,var(--gold),transparent);}
/* body */
.ev-body{padding:32px 36px;}
.ev-lbl{font-family:var(--FM);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:9px;}
.ev-title{font-family:var(--FC);font-style:italic;font-weight:900;font-size:34px;letter-spacing:.02em;text-transform:uppercase;color:var(--t1);margin-bottom:5px;line-height:1;}
.ev-meta{font-family:var(--FM);font-size:10px;color:var(--t3);letter-spacing:.08em;margin-bottom:14px;}
.ev-desc{font-size:14px;line-height:1.75;color:var(--t2);font-weight:300;margin-bottom:16px;max-width:720px;}
.ev-badge{display:inline-flex;align-items:center;gap:7px;font-family:var(--FC);font-style:italic;font-weight:800;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:#100e09;background:var(--gold);padding:5px 14px;}
.ev-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:13px;}

/* ══ EXPERIENCE ══ */
#experience{padding:120px 48px;background:var(--bg2);}
.exp-g{display:grid;grid-template-columns:210px 1fr;gap:60px;}
.exp-nav{position:sticky;top:105px;height:fit-content;}
.eni{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid var(--b0);cursor:auto;}
.eni:first-child{border-top:1px solid var(--b0);}
.en-bar{width:3px;height:26px;background:var(--surf2);border-radius:1px;flex-shrink:0;transition:background .2s;}
.eni.on .en-bar{background:var(--gold);}
.en-co{font-family:var(--FC);font-size:14px;font-weight:800;color:var(--t2);transition:color .2s;letter-spacing:.02em;text-transform:uppercase;}
.eni.on .en-co{color:var(--t1);}
.en-rl{font-family:var(--FM);font-size:10px;color:var(--t3);letter-spacing:.06em;margin-top:1px;}
.exp-cards{display:flex;flex-direction:column;gap:2px;}
.ec{background:var(--bg3);border:1px solid var(--b0);border-radius:1px;padding:30px;position:relative;overflow:hidden;}
.ec::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:transparent;transition:background .25s;}
.ec:hover::before{background:var(--gold);}
.ect{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--b0);}
.ec-co{font-family:var(--FM);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:4px;}
.ec-r{font-family:var(--FC);font-style:italic;font-size:24px;font-weight:900;letter-spacing:.01em;text-transform:uppercase;margin-bottom:3px;color:var(--t1);}
.ec-p{font-family:var(--FM);font-size:10px;color:var(--t3);letter-spacing:.07em;}
.ec-bdg{font-family:var(--FM);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);background:var(--surf);border:1px solid var(--b0);padding:5px 9px;border-radius:1px;}
.ec-ul{list-style:none;display:flex;flex-direction:column;gap:7px;}
.ec-ul li{font-size:13px;line-height:1.65;color:var(--t2);font-weight:300;display:flex;gap:10px;align-items:flex-start;}
.ec-ul li::before{content:"→";color:var(--gold);font-family:var(--FM);font-size:11px;flex-shrink:0;margin-top:1px;}
.ec-sk{display:flex;flex-wrap:wrap;gap:5px;margin-top:14px;padding-top:14px;border-top:1px solid var(--b0);}
/* certs */
.cg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--b0);border:1px solid var(--b0);border-radius:1px;overflow:hidden;margin-top:36px;}
.cci{background:var(--bg2);padding:18px;}
.ccis{font-family:var(--FM);font-size:10px;letter-spacing:.17em;text-transform:uppercase;color:var(--gold);margin-bottom:4px;}
.ccn{font-family:var(--FC);font-style:italic;font-size:16px;font-weight:800;text-transform:uppercase;letter-spacing:.02em;margin-bottom:3px;color:var(--t1);}
.ccd{font-family:var(--FM);font-size:10px;color:var(--t3);}

/* ══ LANGUAGES ══ */
#languages{padding:120px 48px;background:var(--bg);}
.lang-g{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:var(--b0);border:1px solid var(--b0);border-radius:1px;overflow:hidden;}
.lang-card{background:var(--bg2);padding:36px;}
.lang-flag{font-size:32px;margin-bottom:14px;}
.lang-title{font-family:var(--FC);font-style:italic;font-weight:900;font-size:28px;letter-spacing:.04em;text-transform:uppercase;color:var(--t1);margin-bottom:4px;}
.lang-cert{font-family:var(--FM);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;}
.lang-scores{display:flex;flex-direction:column;gap:8px;}
.ls-row{display:flex;align-items:center;gap:12px;}
.ls-label{font-family:var(--FM);font-size:11px;letter-spacing:.08em;color:var(--t2);width:100px;flex-shrink:0;}
.ls-bar-wrap{flex:1;height:6px;background:var(--surf2);border-radius:3px;overflow:hidden;}
.ls-bar{height:100%;background:var(--gold);border-radius:3px;transition:width 1s cubic-bezier(.4,0,.2,1);}
.ls-val{font-family:var(--FM);font-size:11px;color:var(--gold);font-weight:500;width:32px;text-align:right;flex-shrink:0;}
.lang-note{font-family:var(--FM);font-size:10px;color:var(--t3);letter-spacing:.08em;margin-top:14px;line-height:1.6;}

/* ══ GITHUB ══ */
#github{padding:120px 48px;background:var(--bg2);}
.twrap{background:#0a0806;border:1px solid var(--b0);border-radius:1px;overflow:hidden;margin-bottom:2px;}
.tbar{background:#100e09;padding:9px 15px;display:flex;align-items:center;gap:7px;border-bottom:1px solid var(--b0);}
.td{width:11px;height:11px;border-radius:50%;}
.tdr{background:#ff5f57;}.tdy{background:#febc2e;}.tdg{background:#28c840;}
.tpath{font-family:var(--FM);font-size:10px;color:var(--t3);margin-left:8px;}
.tbody{padding:20px;font-family:var(--FM);font-size:12px;line-height:1.85;}
.tl{display:flex;gap:11px;}
.tp{color:var(--gold);}.tc{color:var(--t1);}.to{color:var(--t2);}
.tg{color:#7aaa50;}.toy{color:var(--gold2);}.tgr{color:var(--t3);}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.cgr{display:grid;grid-template-columns:repeat(52,1fr);gap:3px;padding:18px;background:#0a0806;border:1px solid var(--b0);border-radius:1px;margin-bottom:2px;}
.cc{aspect-ratio:1;border-radius:1px;}
.cc0{background:#1a1508;}.cc1{background:#26200a;}.cc2{background:#433500;}
.cc3{background:#6a5200;}.cc4{background:#a88000;}.cc5{background:var(--gold);}
.gsr{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--b0);border:1px solid var(--b0);border-radius:1px;overflow:hidden;}
.gsv{background:var(--bg3);padding:22px;text-align:center;}
.gsn{font-family:var(--FC);font-style:italic;font-size:38px;font-weight:900;line-height:1;margin-bottom:6px;}
.gsl{font-family:var(--FM);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--t3);}

/* ══ CONTACT ══ */
#contact{padding:120px 48px;background:var(--bg2);}
.ct-g{display:grid;grid-template-columns:1fr 1fr;gap:60px;}
.cth{font-family:var(--FC);font-style:italic;font-weight:900;font-size:clamp(44px,5.5vw,84px);letter-spacing:.01em;text-transform:uppercase;line-height:.9;margin-bottom:22px;color:var(--t1);}
.cth .hl{color:var(--gold);}
.cts{font-size:14px;line-height:1.75;color:var(--t2);margin-bottom:32px;font-weight:300;}
.ctls{display:flex;flex-direction:column;gap:8px;}
.ctl{display:flex;align-items:center;gap:13px;text-decoration:none;padding:12px 15px;border:1px solid var(--b0);border-radius:1px;transition:border-color .2s,background .2s;color:var(--t1);}
.ctl:hover{border-color:var(--b1);background:var(--surf);}
.ctl-i{font-family:var(--FM);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);width:60px;flex-shrink:0;}
.ctl-t{font-size:12px;font-weight:500;color:var(--t2);transition:color .2s;}
.ctl:hover .ctl-t{color:var(--t1);}
.ctl-a{margin-left:auto;color:var(--t3);font-family:var(--FM);font-size:12px;transition:color .2s,transform .2s;}
.ctl:hover .ctl-a{color:var(--gold);transform:translateX(4px);}
.ct-form{background:var(--bg3);border:1px solid var(--b0);border-radius:1px;padding:28px;}
.fl{display:block;font-family:var(--FM);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--t3);margin-bottom:6px;}
.fi,.fta{width:100%;background:var(--bg);border:1px solid var(--b0);border-radius:1px;padding:11px 13px;font-family:var(--FB);font-size:14px;color:var(--t1);outline:none;transition:border-color .2s;margin-bottom:14px;resize:none;}
.fi:focus,.fta:focus{border-color:rgba(232,192,64,.35);}
.fta{height:96px;}
.fs{width:100%;background:var(--gold);color:#100e09;border:none;border-radius:1px;padding:12px;font-family:var(--FC);font-style:italic;font-size:20px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;cursor:auto;transition:transform .18s,box-shadow .18s;}
.fs:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(232,192,64,.24);}

footer{padding:30px 48px;background:var(--bg);border-top:1px solid var(--b0);display:flex;align-items:center;justify-content:space-between;}
.fl-logo{font-family:var(--FC);font-style:italic;font-size:22px;font-weight:900;letter-spacing:.03em;text-transform:uppercase;}
.fl-logo span{color:var(--gold);}
.fpa{font-family:var(--FM);font-size:9px;letter-spacing:.11em;color:var(--t3);border:1px solid var(--t3);padding:4px 8px;text-align:center;line-height:1.4;}
.fcpy{font-family:var(--FM);font-size:10px;color:var(--t3);letter-spacing:.06em;}
.ftop{font-family:var(--FM);font-size:10px;color:var(--t3);text-decoration:none;letter-spacing:.1em;transition:color .2s;}
.ftop:hover{color:var(--gold);}

/* REVEAL */
.rv{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease;}
.rv.v{opacity:1;transform:translateY(0);}
.r1{transition-delay:.08s;}.r2{transition-delay:.16s;}.r3{transition-delay:.24s;}

::-webkit-scrollbar{width:3px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:var(--surf2);border-radius:1px;}

@media(max-width:900px){
  body{cursor:auto;}.cr,.crr{display:none;}
  nav{padding:14px 20px;}.nls{display:none;}
  .lsw{right:20px;top:14px;}
  #hero{padding:90px 20px 48px;align-items:flex-start;}
  .hero-g{grid-template-columns:1fr;gap:32px;}
  .hero-photo{justify-content:center;}
  .photo-frame{width:260px;}.photo-frame img{height:360px;}
  .hwm,.hstripe{display:none;}
  #about,#skills,#projects,#events,#experience,#languages,#github,#contact{padding-left:20px;padding-right:20px;}
  .about-g,.ct-g{grid-template-columns:1fr;gap:32px;}
  .skw,.lang-g{grid-template-columns:repeat(2,1fr);}
  .feat{grid-template-columns:1fr;gap:24px;padding:26px;}
  .pg{grid-template-columns:1fr;}
  .ev-img-strip.two,.ev-img-strip.three{grid-template-columns:1fr;}
  .ev-img-strip{height:auto;}
  .ev-img-slot{height:200px;}
  .exp-g{grid-template-columns:1fr;}.exp-nav{display:none;}
  .cg{grid-template-columns:1fr;}
  .cgr{grid-template-columns:repeat(26,1fr);}
  .gsr{grid-template-columns:repeat(2,1fr);}
  footer{flex-direction:column;gap:10px;text-align:center;padding:22px 20px;}
}

/* ── CEFR language bars ── */
.cefr-badge{font-family:var(--FM);font-size:9px;letter-spacing:.1em;padding:3px 7px;border-radius:1px;font-weight:500;}
.cefr-a1{background:rgba(100,100,100,.25);color:#888;}
.cefr-a2{background:rgba(120,140,100,.3);color:#9aaa80;}
.cefr-b1{background:rgba(100,160,100,.3);color:#80bb80;}
.cefr-b2{background:rgba(80,180,120,.3);color:#60cc90;}
.cefr-c1{background:rgba(232,192,64,.25);color:var(--gold);}
.cefr-c2{background:rgba(232,192,64,.5);color:var(--gold2);font-weight:700;}

.lang-test-badge{background:var(--surf);border:1px solid var(--b1);border-radius:1px;padding:10px 14px;text-align:right;flex-shrink:0;}
.ltb-name{font-family:var(--FC);font-style:italic;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--t1);margin-bottom:2px;}
.ltb-detail{font-family:var(--FM);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);margin-bottom:4px;}
.ltb-score{font-family:var(--FM);font-size:11px;color:var(--t2);}
.ltb-score strong{color:var(--gold);font-size:13px;}

.cefr-bar-track{flex:1;display:flex;gap:3px;height:8px;align-items:center;}
.cefr-seg{flex:1;height:8px;border-radius:1px;transition:opacity .3s;}
.cefr-seg.done.cefr-a1{background:#555;}
.cefr-seg.done.cefr-a2{background:#6a8050;}
.cefr-seg.done.cefr-b1{background:#509050;}
.cefr-seg.done.cefr-b2{background:#40aa70;}
.cefr-seg.done.cefr-c1{background:var(--gold);}
.cefr-seg.done.cefr-c2{background:var(--gold2);}
.cefr-seg.empty{background:var(--surf2);opacity:.4;}

.cefr-level-lbl{font-family:var(--FM);font-size:11px;font-weight:700;letter-spacing:.06em;width:28px;text-align:center;flex-shrink:0;}
.c2-lbl{color:var(--gold2);}
.c1-lbl{color:var(--gold);}
.b2-lbl{color:#60cc90;}
.ls-raw{font-family:var(--FM);font-size:10px;color:var(--t3);letter-spacing:.04em;width:54px;text-align:right;flex-shrink:0;}
.ls-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.overall-row{margin-top:8px;padding-top:8px;border-top:1px solid var(--b0);margin-bottom:0;}
.ls-label{font-family:var(--FM);font-size:11px;letter-spacing:.08em;color:var(--t2);width:72px;flex-shrink:0;}


/* ── ABOUT TIMELINE ── */
.about-timeline{position:relative;padding-left:22px;}
.about-timeline::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:1px;background:linear-gradient(180deg,var(--gold),rgba(232,192,64,.1));}
.abt-block{position:relative;margin-bottom:32px;}
.abt-block:last-child{margin-bottom:0;}
.abt-dot{position:absolute;left:-26px;top:4px;width:8px;height:8px;border-radius:50%;background:var(--gold);border:2px solid var(--bg2);box-shadow:0 0 0 2px rgba(232,192,64,.3);}
.abt-label{font-family:var(--FM);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}

/* ── CONCRETE BOYS HERO BG ── */
.cb-bg-text{position:absolute;right:0;top:50%;transform:translateY(-50%);z-index:1;pointer-events:none;user-select:none;display:flex;flex-direction:column;align-items:flex-end;gap:-10px;overflow:hidden;}
.cb-bg-text span{font-family:var(--FC);font-style:italic;font-weight:900;font-size:min(280px,23vw);line-height:.82;letter-spacing:-.03em;text-transform:uppercase;color:transparent;-webkit-text-stroke:1px rgba(232,192,64,.06);white-space:nowrap;}
.cb-grid{position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:linear-gradient(rgba(232,192,64,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(232,192,64,.025) 1px,transparent 1px);
  background-size:60px 60px;}

/* ── RISE photo fix ── */
.rise-strip .ev-img-slot img{object-position:center center;}


100%{background-position:120px 80px}}100%{background-position:120px 80px}}
#hero,#about,#skills,#projects,#events,#experience,#languages,#github,#contact,footer{position:relative;z-index:2;}
body::before{z-index:3;}#sw{z-index:2000;}nav{z-index:500;}

.photo-frame img{object-position:center 15%!important;}

/* Photo slider for project cards */
.proj-slider{position:relative;width:100%;height:200px;overflow:hidden;background:#0a0806;user-select:none;}
.proj-slides{display:flex;height:100%;transition:transform .4s cubic-bezier(.4,0,.2,1);will-change:transform;}
.proj-slide{flex:0 0 100%;height:100%;position:relative;}
.proj-slide img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;}
.slider-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:10;
  width:28px;height:28px;background:rgba(16,14,9,.75);border:1px solid rgba(232,192,64,.35);
  border-radius:1px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:12px;color:var(--gold);transition:background .2s;padding:0;}
.slider-btn:hover{background:rgba(16,14,9,.95);}
.slider-prev{left:8px;}
.slider-next{right:8px;}
.slider-dots{position:absolute;bottom:6px;left:50%;transform:translateX(-50%);
  display:flex;gap:4px;z-index:10;}
.slider-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.3);
  cursor:pointer;transition:background .2s;}
.slider-dot.on{background:var(--gold);}


@media(max-width:900px){
  .ev-img-strip.three,.ev-img-strip.two{grid-template-columns:1fr;}
  .ev-img-slot{height:240px;}
  .ev-body{padding:20px 18px;}
  .ev-title{font-size:22px;}
}


@media(max-width:900px){
  body{cursor:auto;}
  nav{padding:14px 20px;}.nav-links,.nls{display:none;}
  .nav-hamburger{display:flex;}.lang-sw{right:20px;top:14px;}
  #hero{padding:0 20px;}
  .hero-g,.hero-grid{grid-template-columns:1fr;gap:28px;padding:88px 0 48px;}
  .hero-photo{justify-content:center;}
  .photo-frame{width:240px;}.photo-frame img{height:320px;}
  .hero-wm,.hero-stripe,.hwm,.hstripe{display:none;}
  .hero-stats,.hstats{flex-wrap:wrap;gap:16px;}
  .stat-n,.stn{font-size:36px;}
  .hero-btns,.hbtns{flex-wrap:wrap;gap:8px;}
  #about,#skills,#projects,#events,#experience,#languages,#github,#contact{padding-left:20px;padding-right:20px;}
  .about-g,.abg{grid-template-columns:1fr;gap:28px;}
  .s-title,.stit{font-size:clamp(32px,8vw,52px);}
  .skw,.skills-wrap{grid-template-columns:repeat(2,1fr);}
  .feat,.feat-statify{grid-template-columns:1fr;gap:20px;padding:24px 20px;}
  .pg{grid-template-columns:1fr!important;}
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important;}
  .proj-slider{height:180px;}
  .phone-wrap{flex-direction:column;align-items:center;}
  .phone,.phone-device{width:140px;}
  .ev-img-strip,.ev-img-strip.two,.ev-img-strip.three{display:block;}
  .ev-img-slot{height:240px;}
  .ev-body{padding:18px;}
  .ev-title{font-size:20px;}
  .exp-wrap,.exg{grid-template-columns:1fr;}
  .exp-nav,.exnst{display:none;}
  .ec,.exp-card{padding:18px;}
  .cgrd,.certs-grid{grid-template-columns:1fr;}
  .lang-grid{grid-template-columns:1fr;}
  .lang-card{padding:20px;}
  .lang-card-top{flex-direction:column;gap:10px;}
  .lang-test-badge{text-align:left;}
  .cgr,.contrib-grid{grid-template-columns:repeat(26,1fr);}
  .gsr,.gh-stats{grid-template-columns:repeat(2,1fr);}
  .ctg,.contact-grid{grid-template-columns:1fr;gap:24px;}
  .cth,.contact-headline{font-size:clamp(34px,8vw,52px);}
  footer{flex-direction:column;gap:10px;text-align:center;padding:22px 20px;}
  .cb-bg{background-size:88px 58px;}
}
@media(max-width:480px){
  .hname,.hero-name{font-size:clamp(50px,13vw,74px);}
  .s-title,.stit{font-size:clamp(26px,9vw,42px);}
  .skw,.skills-wrap{grid-template-columns:1fr;}
  .ev-img-slot{height:200px;}
  .gsr,.gh-stats{grid-template-columns:1fr;}
}


/* RISE event photo - taller for single image */
.ev-card .ev-img-strip[style*="grid-template-columns:1fr"] .ev-img-slot,
.ev-card .ev-img-strip:not(.two):not(.three) .ev-img-slot {
  height: 380px;
}
.ev-img-strip:not(.two):not(.three) {
  height: 380px;
}





/* ── CB+Cursor repeating pattern ── */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 10;
  background-image: url("data:image/png;base64,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");
  background-repeat: repeat;
  background-size: 120px 80px;
  opacity: 0.12;
  animation: bgDrift 70s linear infinite;
}
@keyframes bgDrift {
  0%   { background-position: 0 0; }
  100% { background-position: 120px 80px; }
}
body::before { z-index: 998; }
nav { z-index: 500; }
#sw { z-index: 2000; }


/* Keyword highlights */
.kw {
  color: var(--gold);
  font-weight: 600;
  position: relative;
  cursor: default;
  transition: text-shadow .3s;
}
.kw:hover {
  text-shadow: 0 0 12px rgba(232,192,64,.55), 0 0 24px rgba(232,192,64,.2);
}
.kw-u {
  color: var(--gold);
  font-weight: 600;
  border-bottom: 1px solid rgba(232,192,64,.4);
  padding-bottom: 1px;
  transition: border-color .3s, text-shadow .3s;
  cursor: default;
}
.kw-u:hover {
  border-color: var(--gold);
  text-shadow: 0 0 10px rgba(232,192,64,.45);
}
/* Quote block glitch */
.cbq {
  font-family: var(--FC);
  font-style: italic;
  font-weight: 900;
  font-size: clamp(18px, 2.2vw, 28px);
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.1;
  color: var(--gold);
  border-left: 3px solid var(--gold);
  padding: 16px 20px;
  background: rgba(232,192,64,.04);
  margin: 32px 0;
  position: relative;
  overflow: hidden;
}
.cbq::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  padding: 16px 20px;
  color: var(--gold2);
  opacity: 0;
  clip-path: polygon(0 30%, 100% 30%, 100% 50%, 0 50%);
  animation: glitch 6s infinite;
}
@keyframes glitch {
  0%, 92%, 100% { opacity: 0; transform: none; }
  93% { opacity: .7; transform: translateX(-3px); }
  95% { opacity: .5; transform: translateX(3px); }
  97% { opacity: .7; transform: translateX(-2px); }
}
/* About section spacing */
.about-p {
  font-size: 15px;
  line-height: 1.85;
  color: var(--t2);
  margin-bottom: 20px;
  font-weight: 300;
}
.about-timeline-label {
  font-family: var(--FM);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--t3);
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  margin-top: 28px;
}
.about-timeline-label::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
}
.about-timeline-label:first-child { margin-top: 0; }


/* About blocks — see keyword system below for .about-block and .about-era */
/* ── KEYWORD SYSTEM ── */
/* Base keyword: gold + weight */
.kw {
  color: var(--gold);
  font-weight: 600;
  letter-spacing: .01em;
  transition: text-shadow .3s, color .2s;
  cursor: default;
  position: relative;
}
.kw:hover {
  color: var(--gold2);
  text-shadow: 0 0 18px rgba(232,192,64,.55), 0 0 40px rgba(232,192,64,.18);
}

/* Underline variant: subtle animated underline */
.kw-u {
  color: var(--gold);
  font-weight: 600;
  letter-spacing: .01em;
  position: relative;
  cursor: default;
  transition: color .2s, text-shadow .3s;
  text-decoration: none;
  border-bottom: 1px solid rgba(232,192,64,.28);
  padding-bottom: 1px;
}
.kw-u:hover {
  color: var(--gold2);
  border-bottom-color: var(--gold2);
  text-shadow: 0 0 14px rgba(232,192,64,.45);
}

/* Bright keyword: larger glow pulse on hover */
.kw-b {
  color: var(--gold2);
  font-weight: 700;
  letter-spacing: .02em;
  cursor: default;
  transition: text-shadow .3s;
}
.kw-b:hover {
  text-shadow: 0 0 22px rgba(245,208,96,.7), 0 0 50px rgba(232,192,64,.22);
}

/* Quote glitch block — rewritten */
.cbq {
  font-family: var(--FC);
  font-style: italic;
  font-weight: 900;
  font-size: clamp(18px, 2.3vw, 30px);
  letter-spacing: .06em;
  text-transform: uppercase;
  line-height: 1.1;
  color: var(--gold);
  border-left: 3px solid var(--gold);
  padding: 20px 24px;
  background: rgba(232,192,64,.035);
  margin: 36px 0;
  position: relative;
  overflow: hidden;
}
/* Scan-line shimmer */
.cbq::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(232,192,64,.04) 50%,
    transparent 100%
  );
  background-size: 100% 8px;
  pointer-events: none;
}
/* Glitch echo */
.cbq::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  padding: 20px 24px;
  color: var(--gold2);
  opacity: 0;
  clip-path: polygon(0 30%, 100% 30%, 100% 55%, 0 55%);
  animation: glitch 9s infinite;
  pointer-events: none;
  letter-spacing: .1em;
}
@keyframes glitch {
  0%,88%,100% { opacity:0; transform:none }
  89% { opacity:.7; transform:translateX(-4px) skewX(-1deg) }
  91% { opacity:.3; transform:translateX(4px) skewX(1deg) }
  93% { opacity:.6; transform:translateX(-2px) }
  95% { opacity:0 }
}

/* About paragraph */
.abp {
  font-size: 15px;
  line-height: 1.88;
  color: var(--t2);
  margin-bottom: 0;
  font-weight: 300;
  letter-spacing: .01em;
}
.abp em { color: var(--t1); font-style: italic; font-weight: 400; }
.abp strong { color: var(--t1); font-weight: 500; }

/* About block spacing */
.about-block { margin-bottom: 34px; }
.about-era {
  font-family: var(--FM);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.about-era::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 8px rgba(232,192,64,.6);
  flex-shrink: 0;
}