/* components.css — About, services, projects, skills, process, contact, footer */

/* ══════════════════════════════════════
   ABOUT
══════════════════════════════════════ */
.ag{display:grid;grid-template-columns:360px 1fr;gap:clamp(32px,6vw,90px);align-items:start}
.apc{aspect-ratio:4/5;border-radius:clamp(16px,3vw,28px);overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;border:1px solid var(--bd);background:var(--bg2);transition:border-color .35s,box-shadow .35s}
.apc:hover{border-color:rgba(var(--ar),.35);box-shadow:0 0 60px rgba(var(--ar),.09)}
.apc-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 60% 15%,var(--glow),transparent 55%),linear-gradient(160deg,var(--bg3),var(--bg2))}
.apc-init{font-size:clamp(55px,10vw,116px);font-weight:900;letter-spacing:-.06em;color:var(--bd);position:relative;z-index:1;line-height:1;text-shadow:0 0 80px var(--glow)}
.apc-foot{position:absolute;bottom:0;left:0;right:0;z-index:2;background:linear-gradient(to top,var(--bg2),transparent);padding:clamp(18px,3vw,32px) clamp(16px,2.5vw,28px) clamp(14px,2vw,22px)}
.apf{display:flex;justify-content:space-between;align-items:flex-end}
.apfn{font-size:clamp(12px,1.4vw,16px);font-weight:700;margin-bottom:4px;color:var(--tx)}
.apfr{font-size:9px;color:var(--mu);letter-spacing:.1em;text-transform:uppercase}
.apfb{background:var(--a);color:#000;font-size:9px;font-weight:800;padding:5px 13px;border-radius:20px;letter-spacing:.07em;text-transform:uppercase}
/* floating icons on photo */
.pfi{position:absolute;z-index:3;display:flex;align-items:center;gap:7px;background:var(--glass);border:1px solid var(--bd2);border-radius:12px;padding:8px 13px;font-size:11px;font-weight:600;backdrop-filter:blur(14px);color:var(--tx);animation:fy 5s ease-in-out infinite}
.pfi1{top:20px;left:20px;animation-delay:0s}
.pfi2{top:20px;right:20px;animation-delay:1.5s}
.pfi3{bottom:110px;right:20px;animation-delay:3s}
.abio{font-size:clamp(13px,1.2vw,16px);line-height:1.95;color:var(--mu);margin-bottom:32px}
.abio strong{color:var(--tx);font-weight:500}
/* chips */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px}
.chip{display:flex;align-items:center;gap:7px;background:var(--bg2);border:1px solid var(--bd);border-radius:40px;padding:7px 15px;font-size:11px;font-weight:600;color:var(--tx);transition:border-color .3s,background .3s}
.chip:hover{border-color:var(--a);background:var(--card-h)}
.cdot{width:5px;height:5px;background:var(--a);border-radius:50%;flex-shrink:0}
.abtns{display:flex;gap:12px;flex-wrap:wrap}
/* stats grid */
.sg{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:38px;border-radius:16px;overflow:hidden;background:var(--bd)}
.sb{background:var(--bg2);padding:clamp(14px,2.5vw,26px) clamp(10px,2vw,18px);text-align:center;transition:background .3s,box-shadow .3s}
.sb:hover{background:var(--card-h)}
.sn{font-size:clamp(20px,3.2vw,40px);font-weight:900;color:var(--a);letter-spacing:-.04em;line-height:1}
.sl{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--mu);margin-top:6px}

/* ══════════════════════════════════════
   SERVICES
══════════════════════════════════════ */
.svch{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:clamp(34px,5vh,56px);flex-wrap:wrap;gap:16px}
.svcg{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--bd);border-radius:22px;overflow:hidden}
.svcc{background:var(--bg);padding:clamp(28px,4vw,52px) clamp(22px,3.5vw,44px);position:relative;overflow:hidden;transition:background .4s}
.svcc::after{content:'';position:absolute;inset:0;background:var(--a);transform:scaleY(0);transform-origin:bottom;transition:transform .55s cubic-bezier(.76,0,.24,1);z-index:0}
.svcc:hover::after{transform:scaleY(1)}
.svcc>*{position:relative;z-index:1}
.svcc:hover .svn,.svcc:hover .svt,.svcc:hover .svd{color:var(--bg)!important}
.svcc:hover .svtg{border-color:rgba(var(--ar),.2)!important;color:var(--bg)!important}
.svcc:hover .svico{background:rgba(var(--ar),.1)!important;border-color:transparent!important}
.svico{width:52px;height:52px;border-radius:14px;background:var(--glow2);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;margin-bottom:26px;overflow:hidden;transition:background .4s,border-color .4s;flex-shrink:0}
.svn{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--mu);letter-spacing:.1em;margin-bottom:11px;transition:color .4s}
.svt{font-size:clamp(17px,2vw,25px);font-weight:800;letter-spacing:-.03em;margin-bottom:13px;line-height:1.1;color:var(--tx);transition:color .4s}
.svd{font-size:13px;line-height:1.85;color:var(--mu);margin-bottom:22px;transition:color .4s}
.svtgs{display:flex;flex-wrap:wrap;gap:7px}
.svtg{font-size:10px;letter-spacing:.07em;text-transform:uppercase;border:1px solid var(--bd);border-radius:20px;padding:4px 12px;color:var(--mu);transition:border-color .4s,color .4s}

/* ══════════════════════════════════════
   PROJECTS
══════════════════════════════════════ */
.prjh{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:clamp(30px,4vh,50px);flex-wrap:wrap;gap:12px}
.prjg{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:var(--bd);border-radius:22px;overflow:hidden}
.pc{background:var(--bg);position:relative;overflow:hidden;cursor:pointer;transition:background .35s,box-shadow .35s}
.pc:hover{
  background:var(--card-h) !important;
  box-shadow:inset 0 0 0 1px var(--card-border),0 0 60px rgba(var(--ar),.06);
}
.pc.wide{grid-column:1/-1}
.pimg{position:relative;height:clamp(160px,20vw,240px);overflow:hidden;background:var(--bg3)}
.pimg svg{width:100%;height:100%}
.pc:hover .pimg::after{content:'';position:absolute;inset:0;background:rgba(var(--ar),.08);pointer-events:none}
.pstripe{position:absolute;top:0;left:0;right:0;height:3px;z-index:2;transition:height .5s cubic-bezier(.76,0,.24,1),opacity .5s}
.pc:hover .pstripe{height:clamp(160px,20vw,240px);opacity:.07}
.ps1{background:linear-gradient(90deg,#C8FF32,#60a5fa)}
.ps2{background:linear-gradient(90deg,#C084FC,#60a5fa)}
.ps3{background:linear-gradient(90deg,#FF7A1A,#FBBF24)}
.ps4{background:linear-gradient(90deg,#4ADE80,#06B6D4)}
.ps5{background:linear-gradient(135deg,#C8FF32,#C084FC,#FF7A1A)}
.pbody{padding:clamp(22px,3vw,36px) clamp(20px,3vw,36px)}
.ptop{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.pidx{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--mu);letter-spacing:.1em}
.parr{width:36px;height:36px;border:1px solid var(--bd);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--mu);transition:background .25s,border-color .25s,transform .4s,color .25s;flex-shrink:0}
.pc:hover .parr{background:var(--a);border-color:var(--a);color:#000;transform:rotate(-45deg)}
.pttl{font-size:clamp(15px,2vw,22px);font-weight:800;letter-spacing:-.03em;margin-bottom:9px;line-height:1.1;color:var(--tx)}
.pdesc{font-size:13px;line-height:1.8;color:var(--mu);margin-bottom:18px;max-width:520px}
.pst{display:flex;flex-wrap:wrap;gap:7px}
.psp{display:flex;align-items:center;gap:5px;font-size:10px;letter-spacing:.06em;color:var(--mu);background:var(--bg3);border:1px solid var(--bd);border-radius:20px;padding:4px 11px;transition:border-color .25s,color .25s}
.pc:hover .psp{border-color:rgba(var(--ar),.25);color:rgba(var(--ar),.9)}

/* ══════════════════════════════════════
   BENTO SKILLS
══════════════════════════════════════ */
.ski{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,72px);align-items:center;margin-bottom:clamp(30px,5vh,52px)}
.sksub{font-size:15px;color:var(--mu);line-height:1.8}
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:2px;background:var(--bd);border-radius:22px;overflow:hidden}
.skc{background:var(--bg);padding:clamp(18px,2.5vw,30px) clamp(14px,2vw,24px);display:flex;flex-direction:column;align-items:flex-start;gap:10px;position:relative;overflow:hidden;transition:background .3s,box-shadow .35s}
.skc:hover{background:var(--card-h);box-shadow:inset 0 0 0 1px var(--card-border),inset 0 1px 0 rgba(var(--ar),.08)}
.skc::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 120%,rgba(var(--ar),.25),transparent 60%);opacity:0;transition:opacity .4s;pointer-events:none}
.skc:hover::before{opacity:1}
.skc>*{position:relative;z-index:1}
.sk2{grid-column:span 2}
.skf{background:var(--bg2);padding:clamp(22px,3vw,38px);display:flex;flex-direction:column;gap:13px;position:relative;overflow:hidden;transition:background .3s,box-shadow .35s}
.skf:hover{background:var(--card-h);box-shadow:inset 0 0 0 1px var(--card-border),0 20px 60px rgba(0,0,0,.3)}
.skf::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 5% 95%,rgba(var(--ar),.2),transparent 55%);opacity:.45;pointer-events:none;transition:opacity .4s}
.skf:hover::after{opacity:.9}
.skf>*{position:relative;z-index:1}
.iw{width:clamp(36px,4vw,50px);height:clamp(36px,4vw,50px);border-radius:12px;background:var(--bg3);border:1px solid var(--bd);display:flex;align-items:center;justify-content:contain;flex-shrink:0;overflow:hidden;transition:background .3s,border-color .3s;align-items:center;justify-content:center}
.skc:hover .iw,.skf:hover .iw{background:var(--glow2);border-color:rgba(var(--ar),.28)}
.iwl{width:clamp(48px,5.5vw,66px);height:clamp(48px,5.5vw,66px);border-radius:16px;background:var(--bg3);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;overflow:hidden;transition:background .3s,border-color .3s}
.skf:hover .iwl{background:var(--glow2);border-color:rgba(var(--ar),.28)}
.sknm{font-size:clamp(11px,1.1vw,14px);font-weight:700;letter-spacing:-.01em;color:var(--tx)}
.skct{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--mu)}
.ftnm{font-size:clamp(15px,2vw,22px);font-weight:800;letter-spacing:-.03em;color:var(--tx)}
.ftds{font-size:12px;color:var(--mu);line-height:1.7}
.bw{height:3px;background:var(--bd);border-radius:2px;overflow:hidden;margin-top:4px}
.bf{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--a),rgba(var(--ar),.4));width:0;transition:width 1.6s cubic-bezier(.19,1,.22,1) .3s}

/* ══════════════════════════════════════
   PROCESS
══════════════════════════════════════ */
.prwp{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,88px);align-items:center}
.prli{display:flex;flex-direction:column}
.pri{display:flex;align-items:flex-start;gap:clamp(14px,2.5vw,26px);padding:clamp(17px,2.5vh,26px) 0;border-bottom:1px solid var(--bd);transition:background .3s}
.pri:first-child{border-top:1px solid var(--bd)}
.prst{width:clamp(34px,3.5vw,44px);height:clamp(34px,3.5vw,44px);flex-shrink:0;border-radius:10px;background:var(--glow2);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--a);font-weight:600;transition:background .3s,border-color .3s,color .3s}
.pri:hover .prst{background:var(--a);color:#000;border-color:var(--a)}
.prh{font-size:clamp(13px,1.3vw,16px);font-weight:700;margin-bottom:5px;color:var(--tx)}
.prp{font-size:13px;color:var(--mu);line-height:1.75}

/* ══════════════════════════════════════
   CONTACT
══════════════════════════════════════ */
.ctwp{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,88px);align-items:start}
.cth{font-size:clamp(44px,7.5vw,108px);font-weight:900;letter-spacing:-.06em;line-height:.88;color:var(--tx);margin-bottom:clamp(24px,4vh,42px)}
.cth .out{-webkit-text-stroke:1.5px var(--tx);color:transparent;transition:-webkit-text-stroke-color .4s}
.cth:hover .out{-webkit-text-stroke-color:var(--a)}
.ctl{display:flex;flex-direction:column;gap:9px;margin-bottom:24px}
.ctlk{display:flex;align-items:center;gap:clamp(10px,1.5vw,16px);padding:clamp(11px,1.5vw,16px) clamp(12px,2vw,22px);border:1px solid var(--bd);border-radius:14px;color:var(--tx);transition:border-color .25s,background .25s,box-shadow .25s}
.ctlk:hover{border-color:var(--card-border);background:var(--card-h);box-shadow:0 0 24px rgba(var(--ar),.07)}
.ctico{width:clamp(32px,3.5vw,42px);height:clamp(32px,3.5vw,42px);flex-shrink:0;border-radius:10px;background:var(--bg3);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;font-size:14px;overflow:hidden;transition:background .3s}
.ctlk:hover .ctico{background:var(--glow2)}
.ctlb{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--mu)}
.ctlv{font-size:clamp(12px,1.2vw,14px);font-weight:600;color:var(--tx)}
.avp{display:flex;align-items:center;gap:9px;background:var(--glow2);border:1px solid rgba(var(--ar),.14);border-radius:12px;padding:clamp(12px,2vw,17px) clamp(13px,2vw,20px);font-size:13px;color:var(--mu)}
.fw{background:var(--bg2);border:1px solid var(--bd);border-radius:clamp(16px,2.5vw,26px);padding:clamp(24px,4vw,48px);transition:border-color .35s,box-shadow .35s}
.fw:hover{border-color:rgba(var(--ar),.22);box-shadow:0 24px 64px rgba(0,0,0,.3),0 0 0 1px rgba(var(--ar),.08)}
.fwt{font-size:clamp(16px,1.6vw,20px);font-weight:700;margin-bottom:clamp(18px,3vh,28px);letter-spacing:-.02em;color:var(--tx)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.fgrp{display:flex;flex-direction:column;gap:7px;margin-bottom:12px}
.flbl{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--mu)}
.finp,.fta{width:100%;background:var(--bg);border:1px solid var(--bd);color:var(--tx);font-family:'Outfit',sans-serif;font-size:15px;padding:clamp(10px,1.5vw,14px) clamp(12px,2vw,18px);border-radius:10px;outline:none;transition:border-color .25s,background .25s,box-shadow .25s}
.finp:focus,.fta:focus{border-color:var(--a);background:var(--card-h);box-shadow:0 0 0 3px rgba(var(--ar),.1)}
.finp::placeholder,.fta::placeholder{color:var(--mu)}
.fta{resize:none;min-height:110px}
.fbtn{width:100%;background:var(--a);color:#000;font-family:'Outfit',sans-serif;font-size:15px;font-weight:700;letter-spacing:.04em;padding:clamp(12px,1.8vw,15px);border-radius:10px;border:none;cursor:none;margin-top:6px;transition:opacity .25s,transform .25s,box-shadow .25s,background .3s}
.fbtn:hover{opacity:.88;transform:translateY(-2px);box-shadow:0 12px 32px var(--glow)}

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
footer{z-index:10;border-top:1px solid var(--bd);padding:clamp(22px,3vw,38px) clamp(16px,5.5vw,68px);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;background:var(--bg2)}
.flogo{font-size:13px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--tx)}
.fcopy{font-size:11px;color:var(--mu)}
.flinks{display:flex;gap:clamp(12px,2.5vw,28px);flex-wrap:wrap}
.flinks a{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--mu);transition:color .25s}
.flinks a:hover{color:var(--a)}
.fav{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--mu)}
.fdot{width:6px;height:6px;background:#4ade80;border-radius:50%;animation:pls 2.5s ease-in-out infinite}