:root{
    --pink:#e6007e;--pink-soft:#ff4dab;--pink-tint:#fff0f8;--pink-deep:#b80064;
    --ink:#16121a;--grey:#5f5866;--line:#ece8ef;--white:#ffffff;--off:#faf8fc;
    --max:1160px;--display:"Sora",system-ui,sans-serif;--body:"Plus Jakarta Sans",system-ui,sans-serif;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:var(--body);background:var(--white);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  .wrap{max-width:var(--max);margin:0 auto;padding:0 28px}
  .reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}
  .reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
  header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:72px}
  .brand{display:flex;align-items:center;text-decoration:none}
  .brand-logo{height:26px;width:auto;display:block}
  .nav-links{display:flex;gap:32px;align-items:center}
  .nav-links a{text-decoration:none;color:var(--ink);font-size:.93rem;font-weight:500;opacity:.82;transition:opacity .2s,color .2s}
  .nav-links a:hover{opacity:1;color:var(--pink)}
  .lang{display:flex;gap:2px;border:1px solid var(--line);border-radius:999px;padding:3px;background:var(--off)}
  .lang button{border:0;background:transparent;font:inherit;font-size:.76rem;font-weight:700;padding:5px 12px;border-radius:999px;cursor:pointer;color:var(--grey);letter-spacing:.04em;transition:background .2s,color .2s}
  .lang button.on{background:var(--pink);color:#fff}
  .nav-toggle{display:none}
  .hero{padding:80px 0 70px;position:relative}
  .hero::before{content:"";position:absolute;top:-120px;left:-160px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(230,0,126,.10),transparent 68%);pointer-events:none;z-index:-1;animation:float 11s ease-in-out infinite reverse}
  @keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(0,-26px)}}
  .hero-inner{display:grid;grid-template-columns:1.25fr .9fr;gap:40px;align-items:center}
  .portrait-wrap{position:relative;display:flex;justify-content:center;align-items:flex-end;min-height:440px}
  .portrait-halo{position:absolute;bottom:0;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,var(--pink) 0%,var(--pink-soft) 45%,transparent 72%);opacity:.16;animation:halo 7s ease-in-out infinite;z-index:0}
  @keyframes halo{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
  .portrait-ring{position:absolute;bottom:10px;width:340px;height:340px;border-radius:50%;border:1.5px dashed var(--pink-soft);opacity:.5;animation:spin 28s linear infinite;z-index:0}
  @keyframes spin{to{transform:rotate(360deg)}}
  .portrait-img{position:relative;z-index:2;width:100%;max-width:300px;filter:drop-shadow(0 24px 40px rgba(230,0,126,.18));animation:rise 1.1s .3s cubic-bezier(.2,.7,.2,1) both}
  @keyframes rise{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:none}}
  .portrait-badge{position:absolute;z-index:3;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 16px;box-shadow:0 12px 30px -12px rgba(22,18,26,.25);font-family:var(--display);font-weight:700;font-size:.9rem;display:flex;align-items:center;gap:8px}
  .portrait-badge .bdot{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 0 rgba(34,197,94,.5);animation:pulse-g 2s infinite}
  @keyframes pulse-g{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 9px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
  .badge-tl{top:18px;left:0;animation:floatb 5s ease-in-out infinite}
  .badge-br{bottom:60px;right:-6px;color:var(--pink);animation:floatb 6s ease-in-out infinite reverse}
  @keyframes floatb{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
  .pill{display:inline-flex;align-items:center;gap:9px;background:var(--pink-tint);color:var(--pink);font-size:.82rem;font-weight:600;padding:7px 15px;border-radius:999px;margin-bottom:26px}
  .pill .dot{width:7px;height:7px;border-radius:50%;background:var(--pink);box-shadow:0 0 0 0 rgba(230,0,126,.4);animation:pulse 2s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(230,0,126,.4)}70%{box-shadow:0 0 0 10px rgba(230,0,126,0)}100%{box-shadow:0 0 0 0 rgba(230,0,126,0)}}
  .hero h1{font-family:var(--display);font-weight:800;font-size:clamp(2.5rem,62px,4.6rem);line-height:1.04;letter-spacing:-.03em;max-width:16ch;margin-bottom:24px}
  .hero h1 .hl{position:relative;color:var(--pink);white-space:nowrap}
  .hero h1 .dotpink{color:var(--pink)}
  .hero h1 .hl::after{content:"";position:absolute;left:0;right:0;bottom:.08em;height:.16em;background:rgba(230,0,126,.18);z-index:-1}
  .hero p.lead{font-size:1.18rem;max-width:54ch;color:var(--grey);margin-bottom:34px}
  .cta-row{display:flex;gap:13px;flex-wrap:wrap}
  .btn{display:inline-block;text-decoration:none;font-weight:600;font-size:.96rem;padding:14px 27px;border-radius:999px;transition:transform .15s,box-shadow .2s,background .2s,color .2s;cursor:pointer;border:0;font-family:inherit}
  .btn-primary{background:var(--pink);color:#fff;box-shadow:0 8px 24px -8px rgba(230,0,126,.55)}
  .btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px -8px rgba(230,0,126,.7)}
  .btn-ghost{background:#fff;color:var(--ink);border:1.5px solid var(--ink)}
  .btn-ghost:hover{background:var(--ink);color:#fff}
  .hero-meta{display:flex;gap:0;margin-top:60px;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--off)}
  .hero-meta div{flex:1;padding:22px 26px;border-right:1px solid var(--line)}
  .hero-meta div:last-child{border-right:0}
  .hero-meta .k{font-family:var(--display);font-size:1.6rem;font-weight:700;color:var(--ink);display:block;line-height:1}
  .hero-meta .k em{color:var(--pink);font-style:normal}
  .hero-meta .l{color:var(--grey);margin-top:7px;display:block;font-size:.88rem}
  .marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--off);overflow:hidden;padding:18px 0}
  .marquee-track{display:flex;gap:54px;width:max-content;animation:scroll 26s linear infinite}
  .marquee:hover .marquee-track{animation-play-state:paused}
  @keyframes scroll{to{transform:translateX(-50%)}}
  .marquee-track span{font-family:var(--display);font-weight:600;font-size:1.05rem;color:var(--grey);white-space:nowrap;display:flex;align-items:center;gap:54px}
  .marquee-track span::after{content:"\2022";color:var(--pink)}
  section.block{padding:92px 0;border-top:1px solid var(--line)}
  .sec-head{display:flex;align-items:center;gap:14px;margin-bottom:24px}
  .sec-num{font-family:var(--display);font-size:.82rem;font-weight:700;color:#fff;background:var(--pink);width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .sec-title{font-family:var(--display);font-size:clamp(1.8rem,3.6vw,2.5rem);font-weight:700;letter-spacing:-.02em}
  .sec-sub{color:var(--grey);max-width:60ch;margin:0 0 40px 44px;font-size:1.04rem}
  .proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  .card{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;transition:transform .25s,box-shadow .25s,border-color .25s}
  .card:hover{transform:translateY(-5px);box-shadow:0 20px 46px -26px rgba(230,0,126,.4);border-color:var(--pink-soft)}
  .card-top{padding:22px 22px 0;display:flex;justify-content:space-between;align-items:center;gap:10px}
  .card-tag{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--pink);background:var(--pink-tint);padding:5px 11px;border-radius:999px}
  .card-flag{font-size:.76rem;color:var(--grey);font-weight:600}
  .card-body{padding:14px 22px 24px}
  .card-body h3{font-family:var(--display);font-size:1.25rem;font-weight:700;margin-bottom:7px;letter-spacing:-.01em}
  .card-body p{font-size:.92rem;color:var(--grey)}
  .work-cta{margin-top:28px;text-align:center}
  .work-cta a{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:#fff;text-decoration:none;font-weight:600;font-size:.95rem;padding:13px 26px;border-radius:999px;transition:background .2s,transform .15s}
  .work-cta a:hover{background:var(--pink-deep);transform:translateY(-2px)}
  .grid-svc{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
  .svc{background:var(--off);border:1px solid var(--line);padding:32px 30px;border-radius:18px;transition:background .25s,border-color .25s,transform .25s}
  .svc:hover{background:var(--pink-tint);border-color:var(--pink-soft);transform:translateY(-4px)}
  .svc .ico{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:12px;background:#fff;border:1px solid var(--line);font-family:var(--display);font-weight:700;color:var(--pink);margin-bottom:18px;font-size:.95rem}
  .svc h3{font-family:var(--display);font-size:1.16rem;font-weight:600;margin-bottom:10px}
  .svc p{font-size:.97rem;color:var(--grey)}
  .process{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
  .step{position:relative;padding:30px 24px;border:1px solid var(--line);border-radius:16px;background:#fff;transition:transform .25s,box-shadow .25s}
  .step:hover{transform:translateY(-4px);box-shadow:0 16px 40px -24px rgba(230,0,126,.35)}
  .step .n{font-family:var(--display);font-size:2.4rem;font-weight:800;color:var(--pink-tint);line-height:1;margin-bottom:8px;-webkit-text-stroke:1.5px var(--pink-soft)}
  .step h4{font-family:var(--display);font-size:1.08rem;font-weight:600;margin-bottom:8px}
  .step p{font-size:.92rem;color:var(--grey)}
  .about-grid{display:grid;grid-template-columns:1.45fr 1fr;gap:52px;align-items:start}
  .about-grid p{margin-bottom:18px;font-size:1.06rem;color:#3b3540}
  .about-card{background:linear-gradient(160deg,var(--ink),#2c2233);color:#fff;padding:34px;border-radius:20px;position:relative;overflow:hidden}
  .about-card::after{content:"";position:absolute;right:-60px;bottom:-60px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(230,0,126,.4),transparent 70%)}
  .about-card h4{font-family:var(--display);font-size:1.05rem;margin-bottom:18px;font-weight:600;position:relative}
  .about-card ul{list-style:none;position:relative}
  .about-card li{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.12);font-size:.93rem}
  .about-card li:last-child{border-bottom:0}
  .about-card li b{color:var(--pink-soft);font-weight:600;text-align:right}
  .faq{max-width:780px}
  .faq details{border:1px solid var(--line);border-radius:14px;margin-bottom:12px;background:#fff;overflow:hidden;transition:border-color .2s}
  .faq details[open]{border-color:var(--pink-soft)}
  .faq summary{cursor:pointer;list-style:none;padding:22px 24px;font-family:var(--display);font-weight:600;font-size:1.05rem;display:flex;justify-content:space-between;align-items:center;gap:16px}
  .faq summary::-webkit-details-marker{display:none}
  .faq summary::after{content:"+";font-size:1.5rem;color:var(--pink);transition:transform .25s;flex-shrink:0}
  .faq details[open] summary::after{transform:rotate(45deg)}
  .faq .ans{padding:0 24px 22px;color:var(--grey);font-size:.99rem}
  .contact{background:var(--pink);color:#fff;border-radius:24px;padding:60px 50px;display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center;position:relative;overflow:hidden}
  .contact::before{content:"";position:absolute;left:-80px;top:-80px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.10);animation:float 10s ease-in-out infinite}
  .contact h2{font-family:var(--display);font-size:clamp(1.9rem,4vw,2.9rem);font-weight:700;line-height:1.04;margin-bottom:16px;position:relative}
  .contact p{opacity:.95;max-width:40ch;position:relative}
  .contact-info{display:flex;flex-direction:column;gap:15px;position:relative}
  .contact-info a,.contact-info span{color:#fff;text-decoration:none;font-size:1.04rem;display:flex;align-items:center;gap:11px;opacity:.96;transition:transform .2s}
  .contact-info a:hover{text-decoration:underline;transform:translateX(4px)}
  footer{padding:38px 0;border-top:1px solid var(--line);font-size:.86rem;color:var(--grey)}
  footer .wrap{display:flex;justify-content:space-between;width:100%;flex-wrap:wrap;gap:12px}
  @media(max-width:860px){
    .nav-links{position:fixed;inset:72px 0 auto 0;background:#fff;flex-direction:column;gap:0;padding:8px 0;border-bottom:1px solid var(--line);transform:translateY(-150%);transition:transform .3s}
    .nav-links.open{transform:translateY(0)}
    .nav-links a{padding:14px 28px;width:100%}
    .nav-toggle{display:block;background:none;border:0;font-size:1.5rem;cursor:pointer;color:var(--ink)}
    .lang{margin:8px 28px}
    .hero-inner{grid-template-columns:1fr;gap:10px}
    .portrait-wrap{min-height:360px;order:-1}
    .portrait-img{max-width:300px}
    .portrait-halo{width:300px;height:300px}.portrait-ring{width:270px;height:270px}
    .hero-meta{flex-direction:column}
    .hero-meta div{border-right:0;border-bottom:1px solid var(--line)}
    .about-grid,.contact,.grid-svc,.process,.proj-grid{grid-template-columns:1fr}
    .sec-sub{margin-left:0}
    .contact{padding:42px 30px}
  }
  @media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}}
  :focus-visible{outline:2px solid var(--pink);outline-offset:3px}
/* footer social icons */
.footer-social{display:flex;gap:10px;align-items:center}
.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);color:var(--grey);text-decoration:none;font-size:.95rem;transition:background .2s,color .2s,border-color .2s,transform .2s}
.footer-social a:hover{background:var(--pink);color:#fff;border-color:var(--pink);transform:translateY(-2px)}
.contact-info i{width:18px;text-align:center}
@media(max-width:860px){footer .wrap{justify-content:center;text-align:center}}

/* ===== CONTACT FORM ===== */
.contact{align-items:start}
.contact-left h2{margin-bottom:16px}
.contact-form-wrap{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:18px;padding:26px;backdrop-filter:blur(4px)}
.form-or{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;opacity:.85;margin-bottom:16px;color:#fff}
.contact-form .field{margin-bottom:14px}
.contact-form label{display:block;font-size:.82rem;font-weight:600;margin-bottom:6px;color:#fff;opacity:.95}
.contact-form input,.contact-form textarea{width:100%;border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.95);border-radius:10px;padding:12px 14px;font-family:inherit;font-size:.96rem;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.35)}
.contact-form textarea{resize:vertical;min-height:96px}
.btn-form{width:100%;background:var(--ink);color:#fff;border:0;border-radius:10px;padding:14px;font-family:var(--display);font-weight:600;font-size:.98rem;cursor:pointer;transition:background .2s,transform .15s;margin-top:4px}
.btn-form:hover{background:#000;transform:translateY(-2px)}
.hp{position:absolute;left:-9999px}
.form-status{font-size:.9rem;margin-top:12px;font-weight:600;min-height:1.2em}
.form-status.ok{color:#bbf7d0}
.form-status.err{color:#fecaca}

/* ===== CTA BAND ===== */
.cta-band{padding:0 0 8px}
.cta-inner{max-width:var(--max);margin:0 auto;background:linear-gradient(135deg,var(--ink),#2c2233);color:#fff;border-radius:22px;padding:40px 44px;display:flex;align-items:center;justify-content:space-between;gap:30px;position:relative;overflow:hidden}
.cta-inner::before{content:"";position:absolute;right:-50px;top:-50px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(230,0,126,.45),transparent 70%);pointer-events:none;z-index:0}
.cta-inner h3{font-family:var(--display);font-size:clamp(1.4rem,3vw,1.9rem);font-weight:700;margin-bottom:8px;position:relative}
.cta-inner p{opacity:.9;position:relative;max-width:46ch}
.btn-light{flex-shrink:0;background:#fff;color:var(--ink);position:relative;white-space:nowrap;z-index:2}
.btn-light:hover{background:var(--pink);color:#fff;transform:translateY(-2px)}

@media(max-width:860px){
  .cta-inner{flex-direction:column;align-items:flex-start;padding:32px 28px}
}

/* clickable project cards */
a.card{text-decoration:none;color:inherit;display:block}
.card-link{font-family:var(--display);font-weight:600;font-size:.9rem;color:var(--pink)}
.card-link-ico{color:var(--pink);font-size:.82rem;transition:transform .2s}
a.card:hover .card-link-ico{transform:translateX(4px)}
.card-body{display:flex;flex-direction:column}
.card-body p{flex:1}
.card-body .card-link{margin-top:12px}

/* two-column form rows */
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.field-row{grid-template-columns:1fr}}


/* ===== CONTACT — SOBER DESIGN (touch of pink) ===== */
.contact-new{display:grid;grid-template-columns:320px 1fr;gap:48px;align-items:start;margin-top:8px;background:var(--off);border:1px solid var(--line);border-radius:24px;padding:40px}
.contact-aside{display:flex;flex-direction:column;gap:8px}
.cinfo{display:flex;align-items:center;gap:14px;padding:14px 6px;text-decoration:none;color:var(--ink);border-bottom:1px solid var(--line);transition:gap .2s}
.cinfo:last-of-type{border-bottom:0}
a.cinfo:hover{gap:18px}
.cinfo-ico{flex-shrink:0;width:42px;height:42px;border-radius:11px;background:#fff;border:1px solid var(--line);color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:1rem;transition:color .2s,border-color .2s}
a.cinfo:hover .cinfo-ico{color:var(--pink);border-color:var(--pink-soft)}
.cinfo-txt{display:flex;flex-direction:column;font-size:.96rem;line-height:1.4;word-break:break-word}
.cinfo-txt b{font-family:var(--display);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--grey);margin-bottom:3px}
.contact-socials{display:flex;gap:10px;margin-top:18px}
.contact-socials a{width:42px;height:42px;border-radius:11px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--grey);text-decoration:none;font-size:1rem;background:#fff;transition:color .2s,border-color .2s,transform .2s}
.contact-socials a:hover{color:var(--pink);border-color:var(--pink-soft);transform:translateY(-2px)}

.contact-card{background:transparent}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.field-row{grid-template-columns:1fr}}
.contact-card .field{margin-bottom:16px}
.contact-card label{display:block;font-family:var(--display);font-size:.76rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--grey);margin-bottom:7px}
.contact-card input,.contact-card textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:11px;padding:13px 15px;font-family:inherit;font-size:.97rem;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.contact-card input:focus,.contact-card textarea:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 3px rgba(230,0,126,.1)}
.contact-card textarea{resize:vertical;min-height:120px}
.contact-card .btn-form{width:100%;background:var(--ink);color:#fff;border:0;border-radius:11px;padding:15px;font-family:var(--display);font-weight:600;font-size:1rem;cursor:pointer;transition:background .2s,transform .15s;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:10px}
.contact-card .btn-form::after{content:"\2192";color:var(--pink-soft);font-size:1.15rem;transition:transform .2s}
.contact-card .btn-form:hover{background:#000;transform:translateY(-2px)}
.contact-card .btn-form:hover::after{transform:translateX(4px)}
.contact-card .form-status{margin-top:12px;font-size:.9rem;font-weight:600;min-height:1.2em}
.contact-card .form-status.ok{color:#15803d}
.contact-card .form-status.err{color:#dc2626}

@media(max-width:860px){
  .contact-new{grid-template-columns:1fr;gap:32px;padding:28px}
}

/* role badge on project cards */
.card-role{display:inline-flex;align-items:center;gap:7px;font-size:.8rem;font-weight:600;color:var(--grey);background:var(--off);border:1px solid var(--line);padding:4px 11px;border-radius:999px;margin-top:12px;width:fit-content}
.card-role i{color:var(--pink);font-size:.78rem}
.card-body .card-link{margin-top:14px}

/* ===== SKILLS ===== */
.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.skill{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;transition:transform .25s,box-shadow .25s,border-color .25s}
.skill:hover{transform:translateY(-4px);box-shadow:0 18px 40px -26px rgba(230,0,126,.3);border-color:var(--pink-soft)}
.skill-ico{width:48px;height:48px;border-radius:13px;background:var(--pink-tint);color:var(--pink);display:flex;align-items:center;justify-content:center;font-size:1.15rem;margin-bottom:16px}
.skill h3{font-family:var(--display);font-size:1.12rem;font-weight:600;margin-bottom:9px}
.skill p{font-size:.95rem;color:var(--grey)}
@media(max-width:860px){.skills-grid{grid-template-columns:1fr}}
