:root{
  --bg:#f6f7fb; --text:#0b1020; --muted:#667085;
  --brand:#7c3aed; --brand-100:#ede9fe; --brand-300:#c4b5fd;
  --accent:#06b6d4; --card:#ffffff; --ring:rgba(124,58,237,.22); --max:1160px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;overflow-x:hidden;max-width:100vw;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 16px}
.section{padding:28px 0}
.badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:700;padding:.4rem .8rem;border-radius:999px;background:var(--brand-100);color:#4c1d95}
.card{background:var(--card);border-radius:22px;padding:22px}
.shadow{box-shadow:0 10px 30px rgba(0,0,0,.08)}
@media (max-width: 900px){
  .shadow{box-shadow:0 6px 18px rgba(0,0,0,.06)}
}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.2rem;border-radius:999px;font-weight:700;transition:.2s}
.btn-primary{background:var(--brand);color:#fff}
.btn-outline{border:1px solid #e5e7eb}
.muted{color:var(--muted)}
.grid{display:grid;gap:24px}
.cols-2{grid-template-columns:1fr}
.work .cards{grid-template-columns:1fr}
@media(min-width:860px){.cols-2{grid-template-columns:1.1fr .9fr}.work .cards{grid-template-columns:repeat(3,1fr)}}

header{position:sticky;top:0;z-index:40;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,255,255,.98));border-bottom:1px solid #eef2ff;transform:translateZ(0)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{font-weight:800;font-size:1.6rem;letter-spacing:-.02em}
.nav a{position:relative;padding:.4rem .2rem}
.nav a:after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--brand);opacity:0;transform:translateY(4px);transition:.2s}
.nav a:hover:after{opacity:1;transform:translateY(0)}

.menu-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:999px;background:var(--brand);color:#fff;border:none;cursor:pointer;box-shadow:0 6px 18px rgba(124,58,237,.25)}
.backdrop{will-change:opacity;position:fixed;inset:0;background:rgba(2,6,23,.75);opacity:0;pointer-events:none;transition:.2s;z-index:50}
.backdrop.open{opacity:1;pointer-events:auto}
.drawer{will-change:transform;position:fixed;top:0;right:0;height:calc(100dvh - 24px);width:84vw;max-width:360px;background:#fff;transform:translateX(100%);opacity:1;transition:transform .24s ease;z-index:60;padding:16px;border:1px solid #eef2f7;display:flex;flex-direction:column;gap:10px;visibility:hidden;pointer-events:none;box-shadow:0 20px 50px rgba(15,23,42,.10);margin:12px;border-radius:18px;overflow:hidden}
.drawer.open{transform:translateX(0);visibility:visible;pointer-events:auto}
.drawer .close{align-self:flex-end;width:40px;height:40px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;font-weight:800;cursor:pointer}
.drawer .head{display:flex;align-items:center;gap:12px;padding:6px 4px 12px;border-bottom:1px dashed #e9e7ff;margin-bottom:6px}
.drawer .avatar{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#7c3aed,#06b6d4)}
.drawer a{display:flex;align-items:center;gap:10px}
.drawer a .ico{width:20px;height:20px;border-radius:6px;background:#f5f3ff;display:inline-flex;align-items:center;justify-content:center;color:#7c3aed;font-weight:700}

.hero h1{letter-spacing:-.02em;font-size:clamp(2rem,5vw,3rem);margin:.4rem 0}
.hero p{max-width:60ch}

.work .thumb{border-radius:16px;aspect-ratio:16/9;object-fit:cover}
.work .card-inner{padding-top:12px}
.tag{display:inline-flex;align-items:center;padding:.25rem .6rem;border-radius:999px;background:var(--brand-100);color:#4c1d95;font-size:.8rem;font-weight:700;margin-bottom:6px}

footer{padding:26px 0;border-top:1px solid #eef2ff;margin-top:20px}
footer .wrap{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
footer a{color:#334155}

#contact{padding-top:36px;padding-bottom:46px}
#contact .contact-grid{display:grid;gap:22px}
@media(min-width:860px){#contact .contact-grid{grid-template-columns:1.1fr .9fr}}
#contact .card{border-radius:24px;padding:22px 20px 24px;background:linear-gradient(180deg,#ffffff 0%, #f8f9ff 100%);box-shadow:0 10px 30px rgba(124,58,237,.06)}
#contact h2{margin-top:0;margin-bottom:8px;letter-spacing:-.01em}
#contact p.muted{margin-top:0;margin-bottom:14px}

form .row{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:760px){form .row{grid-template-columns:repeat(2,1fr)}}
form .row .full{grid-column:1 / -1}
label{display:block;margin-bottom:2px}
label span{display:block;font-size:.84rem;color:#60717f;margin:0 0 8px 2px}
input, textarea{display:block;width:100%;margin:0;background:#fff;border:1px solid #e3e6ef;border-radius:14px;padding:13px 14px;font-size:1rem;outline:0;transition:border-color .2s, box-shadow .2s}
input::placeholder, textarea::placeholder{color:#9aa7b2}
input:focus, textarea:focus{border-color:#b1a7ff;box-shadow:0 0 0 4px rgba(124,58,237,.15)}
textarea{min-height:120px}
.actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:6px}
.actions .btn{height:44px;padding:0 18px;border-radius:999px}
.actions .alt{font-size:.95rem}

.bg-wrap{position:absolute;inset:0;overflow:hidden;z-index:-1}
.bg{position:absolute;inset:-10vh -10vw}
.bg .g1,.bg .g2,.bg .g3{position:absolute;inset:0;filter:blur(18px);opacity:.75;pointer-events:none;contain:paint;will-change:transform}
.bg .g2{mix-blend-mode:multiply}

/* Reduce background effects on small screens for smoother scrolling */
@media (max-width: 900px){
  .bg-wrap{display:none}
}


/* ===== Modern Drawer (Frosted + Animated) ===== */
.backdrop{will-change:opacity;position:fixed;inset:0;background:rgba(2,6,23,.75);opacity:0;pointer-events:none;transition:.2s;z-index:50}
.drawer{will-change:transform;position:fixed;top:0;right:0;height:calc(100dvh - 24px);width:84vw;max-width:360px;background:#fff;transform:translateX(100%);opacity:1;transition:transform .24s ease;z-index:60;padding:16px;border:1px solid #eef2f7;display:flex;flex-direction:column;gap:10px;visibility:hidden;pointer-events:none;box-shadow:0 20px 50px rgba(15,23,42,.10);margin:12px;border-radius:18px;overflow:hidden}
.drawer.open{transform:translateX(0);visibility:visible;pointer-events:auto}
@keyframes drawerShow{from{transform:translateX(8%);opacity:.4}to{transform:translateX(0);opacity:1}}
@keyframes drawerHide{from{transform:translateX(0);opacity:1}to{transform:translateX(8%);opacity:.4}}

.drawer .profile{
  display:flex;align-items:center;gap:12px;padding:6px 4px 14px;border-bottom:1px dashed #e9e7ff;margin-bottom:8px
}
.drawer .avatar{
  width:48px;height:48px;border-radius:14px;
  background:conic-gradient(from 180deg at 50% 50%, #06b6d4 0deg, #7c3aed 180deg, #06b6d4 360deg);
  position:relative;
}
.drawer .avatar:after{content:"";position:absolute;right:-2px;bottom:-2px;width:12px;height:12px;border-radius:999px;background:#22c55e;border:2px solid #fff}
.drawer .title{font-weight:800}
.drawer .subtitle{font-size:.86rem;color:var(--muted)}

.menu{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.menu a{display:flex;align-items:center;gap:12px;padding:10px 8px;border-radius:12px;transition:.18s}
.menu a:hover{background:rgba(124,58,237,.08)}
.menu .icon{flex:0 0 32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:#f3f4f6;color:transparent;font-size:0}
.menu .text{display:flex;flex-direction:column}
.menu .text small{color:var(--muted);font-size:.82rem;margin-top:2px}

.drawer .footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:8px;border-top:1px dashed #e9e7ff}
.theme-toggle{display:inline-flex;align-items:center;gap:8px;border:1px solid #e5e7eb;border-radius:999px;padding:6px 10px;cursor:pointer;font-size:.9rem}
.socials{display:flex;gap:10px}
.socials a{width:36px;height:36px;border-radius:10px;border:1px solid #e5e7eb;display:inline-flex;align-items:center;justify-content:center}

/* ===== Dark theme support ===== */


/* ===== Dark Mode Polish ===== */

/* page bg + header */

/* hero + text */

/* cards */

/* badges & tags */

/* buttons/links */

/* inputs */

/* drawer already solid in dark; tweak icons/text */

/* footer */

/* background blobs tuned for dark */

/* responsive fixes: ensure no horizontal scroll in dark */


/* === Modern CTA button (FLAT) === */
.btn-cta{
  display:inline-flex;align-items:center;justify-content:center;
  padding:0.95rem 1.35rem;border-radius:14px;
  font-weight:800;letter-spacing:.01em;min-height:48px;
  background:var(--brand);color:#fff;border:1px solid rgba(0,0,0,0);
  box-shadow:0 8px 18px rgba(124,58,237,.22);
  transition:transform .12s ease, box-shadow .18s ease, filter .18s ease, background-color .18s ease;
}
.btn-cta:hover{filter:brightness(1.05);box-shadow:0 10px 22px rgba(124,58,237,.28)}
.btn-cta:active{transform:translateY(1px);filter:brightness(0.98)}
.btn-cta:focus-visible{outline:none;box-shadow:0 0 0 4px var(--ring), 0 10px 22px rgba(124,58,237,.30)}

/* Dark mode: slightly lighter brand for contrast */
.btn-cta span{display:inline-block}


/* Minimal drawer profile/menu */
.drawer .profile{display:flex;align-items:center;gap:10px;padding:2px 2px 10px;border-bottom:1px dashed #eef2f7;margin-bottom:6px}
.drawer .avatar{width:40px;height:40px;border-radius:10px;background:#f3f4f6}
.drawer .title{font-weight:800}
.drawer .subtitle{font-size:.86rem;color:var(--muted)}
.menu{display:flex;flex-direction:column;gap:4px;margin-top:4px}
.menu a{display:flex;align-items:center;gap:12px;padding:12px 10px;border-radius:12px;transition:background-color .15s}
.menu a:hover{background:#f7f7fb}
.menu .icon{flex:0 0 32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:#f3f4f6;color:transparent;font-size:0}
.menu .text{display:flex;flex-direction:column}
.menu .text small{color:var(--muted);font-size:.8rem;margin-top:2px}
.drawer .footer{margin-top:auto;display:flex;align-items:center;justify-content:flex-end;gap:10px;padding-top:8px;border-top:1px dashed #eef2f7}
.socials{display:flex;gap:8px}
.socials a{width:32px;height:32px;border-radius:8px;border:1px solid #e5e7eb;display:inline-flex;align-items:center;justify-content:center}

section{content-visibility:auto;contain-intrinsic-size:800px}

@media (prefers-reduced-motion: reduce){
  html,body{scroll-behavior:auto}
  .btn-cta,.menu a,.drawer{will-change:transform;transition:none}
  .bg-wrap{display:none !important}
}
