/* ============================================================
   VLADMAXDESIGN — shared styles for multi-page (portfolio, project)
   ============================================================ */
:root{
  --paper:#F4F2EA; --paper-2:#E8E6DA;
  --ink:#121212; --ink-soft:#56544c;
  --violet:#7A3CFF; --violet-deep:#5e23e0;
  --lime:#C8FF3D; --line:#1212121a;
  --display:"Bricolage Grotesque",system-ui,sans-serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --container:1280px; --gutter:clamp(20px,5vw,72px);
  --sec-y:clamp(60px,9vw,120px); --ease:cubic-bezier(.22,1,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;background:var(--paper)}
body{background:transparent;color:var(--ink);font-family:var(--body);font-size:clamp(15px,1.05vw,17px);line-height:1.6;overflow-x:hidden}
::selection{background:var(--violet);color:#fff}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--container);margin:0 auto;padding-inline:var(--gutter)}
h1,h2,h3{font-family:var(--display);font-weight:700;line-height:.98;letter-spacing:-.03em}
h1{font-size:clamp(44px,8vw,104px)}
h2{font-size:clamp(30px,5vw,60px)}
h3{font-size:clamp(20px,2vw,26px);letter-spacing:-.02em}
.eyebrow{font-family:var(--mono);font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--violet);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"✦";color:var(--violet);font-size:11px}

/* cosmic canvas */
#fx{position:fixed;inset:0;width:100vw;height:100vh;z-index:-1;pointer-events:none}

/* custom cursor */
@media (pointer:fine){
  .has-cursor,.has-cursor *{cursor:none!important}
  .cur-dot,.cur-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);will-change:transform}
  .cur-dot{width:7px;height:7px;background:var(--violet);transition:width .2s,height .2s,background .2s}
  .cur-ring{width:34px;height:34px;border:2px solid var(--ink);opacity:.85;transition:width .25s var(--ease),height .25s var(--ease),border-color .25s,background .25s}
  .cur-ring.hot{width:56px;height:56px;border-color:var(--violet);background:#7a3cff14}
  .cur-dot.hot{background:var(--lime)}
}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--body);font-weight:600;font-size:15.5px;padding:15px 26px;border-radius:999px;cursor:pointer;border:2px solid var(--ink);transition:transform .5s var(--ease),background .3s,color .3s,border-color .3s}
.btn-fill{background:var(--ink);color:var(--paper)}
.btn-fill:hover{background:var(--violet);border-color:var(--violet);color:#fff}
.btn-out{background:transparent;color:var(--ink)}
.btn-out:hover{background:var(--ink);color:var(--paper)}

/* nav */
.vmark .v{fill:var(--ink)}.vmark .sp{fill:var(--violet)}
header.nav{position:fixed;inset:0 0 auto 0;z-index:200;transition:.4s;background:var(--paper)}
.nav.scrolled{box-shadow:0 1px 0 var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:78px;gap:20px}
.brand{display:flex;align-items:center;gap:11px}
.brand .vmark{width:30px;height:30px}
.logo{font-family:var(--display);font-weight:800;font-size:22px;letter-spacing:-.045em}
.logo .mx,.logo .sp{color:var(--violet)}
.nav-links{display:flex;gap:26px;align-items:center}
.nav-links a{font-size:15px;font-weight:500;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-4px;height:2px;width:0;background:var(--violet);transition:width .35s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
@media(max-width:760px){.nav-links a:not(.cta):not(.active){display:none}}

/* page shell */
.page{padding-top:128px;padding-bottom:var(--sec-y);min-height:60vh}
.back-link{font-family:var(--mono);font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--violet);display:inline-flex;gap:8px;align-items:center;margin-bottom:26px}
.back-link:hover{color:var(--violet-deep)}

/* portfolio grid */
.pf-intro{max-width:24ch;margin-bottom:46px}
.pf-intro .eyebrow{margin-bottom:20px}
.pf-intro p{color:var(--ink-soft);font-size:clamp(16px,1.4vw,20px);max-width:52ch;margin-top:18px}
.case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.4vw,34px)}
@media(max-width:680px){.case-grid{grid-template-columns:1fr}}
.case-card{border:2px solid var(--ink);border-radius:22px;overflow:hidden;background:var(--paper);transition:transform .55s var(--ease),box-shadow .5s;display:flex;flex-direction:column}
.case-card:hover{transform:translateY(-8px);box-shadow:14px 14px 0 var(--violet)}
.case-card .shot{aspect-ratio:16/11;position:relative;overflow:hidden;border-bottom:2px solid var(--ink);background:linear-gradient(140deg,#7A3CFF,#a877ff);display:flex;align-items:center;justify-content:center}
.case-card .shot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.case-card .shot .ph{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#fff}
.case-card .info{padding:22px 24px 26px;flex:1;display:flex;flex-direction:column;gap:8px}
.case-card .info .top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.case-card .info h3{font-size:23px}
.case-card .tag{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);border:1.5px solid var(--ink);border-radius:999px;padding:6px 12px;white-space:nowrap}
.case-card .sum{color:var(--ink-soft);font-size:14.5px}
.case-card .go{font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--violet);margin-top:auto;padding-top:10px}

/* view-more button (homepage + portfolio) */
.view-more{display:flex;justify-content:center;margin-top:46px}

/* case study (project page) */
.case-hero{margin-bottom:40px}
.case-hero .meta-tag{margin-bottom:18px}
.case-hero h1{margin-bottom:18px}
.case-hero .lead{color:var(--ink-soft);font-size:clamp(17px,1.6vw,22px);max-width:60ch}
.case-meta{display:flex;flex-wrap:wrap;gap:34px;margin:34px 0 0;padding-top:26px;border-top:2px solid var(--ink)}
.case-meta .m .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--violet);margin-bottom:6px}
.case-meta .m .v{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-.01em}
.case-cover{margin:40px 0;border:2px solid var(--ink);border-radius:22px;overflow:hidden}
.case-cover img{width:100%;display:block}
.case-body{max-width:70ch;font-size:clamp(16px,1.3vw,18px);color:#2a2823;white-space:pre-wrap;margin-bottom:20px}
.case-gallery{display:flex;flex-direction:column;gap:clamp(16px,2.4vw,30px);margin-top:30px}
.case-gallery img{width:100%;border:2px solid var(--ink);border-radius:18px;display:block}
.case-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:44px;padding-top:34px;border-top:2px solid var(--ink)}
.case-missing{text-align:center;padding:60px 20px;color:var(--ink-soft)}

/* footer */
footer{padding-block:54px 36px}
.foot-top{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:40px}
.foot-top .brand .vmark{width:46px;height:46px}
.foot-top .logo{font-size:clamp(34px,6vw,60px);letter-spacing:-.05em}
.foot-links{display:flex;gap:22px;flex-wrap:wrap;align-items:center}
.foot-links a{font-family:var(--mono);font-size:12.5px;letter-spacing:.08em;text-transform:uppercase}
.foot-links .s{color:var(--violet)}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:26px;border-top:2px solid var(--ink);font-family:var(--mono);font-size:12px;letter-spacing:.05em;color:var(--ink-soft)}

.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
