/* ═══════════════════════════════════════════════════════════
   Pegify · Shared Styles
   Design tokens, cursor, nav, footer, roll-char, magnetic
   ═══════════════════════════════════════════════════════════ */

:root{
  --paper:#ece9df; --sheet:#f8f6ef; --soft:#f0ede4; --line:#d8d2c4;
  --ink:#1a1a1a; --ink-2:#2a2a26; --muted:#7a766d;
  --orange:#ff7d2f; --orange-deep:#e25b15;
  --green:#23472b; --green-2:#2d5a36; --mint:#bff4c7; --lav:#edd4f8;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;cursor:none}
::selection{background:var(--orange);color:#fff}
button,input,textarea,select{font:inherit;color:inherit}
button{cursor:none;background:none;border:0;padding:0;color:inherit}
a{color:inherit;text-decoration:none;cursor:none}
img,svg{display:block;max-width:100%}
::-webkit-scrollbar{width:0;height:0}
@media (hover:none),(pointer:coarse){body,a,button{cursor:auto} .cursor,.cursor-dot{display:none!important}}

/* ─── Custom cursor ─── */
.cursor{position:fixed;top:0;left:0;width:42px;height:42px;border-radius:999px;background:transparent;border:1.5px solid var(--ink);transform:translate(-50%,-50%);z-index:1000;pointer-events:none;mix-blend-mode:difference;transition:width .35s cubic-bezier(.2,.8,.2,1),height .35s cubic-bezier(.2,.8,.2,1),border-color .25s,background .25s,opacity .25s;will-change:transform;display:grid;place-items:center}
.cursor-label{color:#000;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:0;transform:scale(.6);transition:opacity .2s,transform .25s cubic-bezier(.2,.8,.2,1);white-space:nowrap;line-height:1.05}
.cursor.hover{width:96px;height:96px;background:var(--orange);border-color:var(--orange);mix-blend-mode:normal}
.cursor.hover .cursor-label{opacity:1;transform:scale(1);color:#fff}
.cursor.text{width:120px;height:120px;background:var(--ink);border-color:var(--ink);mix-blend-mode:normal}
.cursor.text .cursor-label{opacity:1;transform:scale(1);color:var(--paper)}
.cursor-dot{position:fixed;top:0;left:0;width:6px;height:6px;border-radius:999px;background:var(--ink);transform:translate(-50%,-50%);z-index:1001;pointer-events:none;mix-blend-mode:difference;transition:opacity .2s;will-change:transform}
.cursor.hover ~ .cursor-dot,.cursor.text ~ .cursor-dot{opacity:0}

/* ─── Roll-char hover ─── */
.roll{display:inline-flex;overflow:hidden;line-height:1;vertical-align:bottom}
.roll .rc{display:inline-block;position:relative;transition:transform .55s cubic-bezier(.16,1,.3,1);transition-delay:calc(var(--i,0)*22ms);will-change:transform}
.roll .rc::after{content:attr(data-c);position:absolute;left:0;top:100%;color:var(--orange)}
.roll:hover .rc{transform:translateY(-100%)}

/* ─── Magnetic ─── */
.mg{position:relative;display:inline-flex;align-items:center;justify-content:center;will-change:transform;transition:transform .35s cubic-bezier(.2,.8,.2,1)}

/* ─── Nav ─── */
.nav{position:fixed;top:0;left:0;right:0;height:80px;display:flex;align-items:center;justify-content:space-between;padding:0 32px;z-index:80;transition:background .35s,border-color .35s,backdrop-filter .35s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(236,233,223,.82);backdrop-filter:blur(16px) saturate(120%);-webkit-backdrop-filter:blur(16px) saturate(120%);border-bottom-color:var(--line)}
.nav-brand{display:flex;align-items:center;gap:14px}
.nav-brand .nav-logo{height:24px;width:auto}
.nav-brand .nav-logo path{fill:var(--ink)}
.nav-brand .tag{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);padding-left:14px;border-left:1px solid var(--line);line-height:1.1}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{padding:10px 14px;border-radius:999px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);transition:background .2s,color .2s}
.nav-links a:hover,.nav-links a.active{background:var(--ink);color:var(--sheet)}
.nav-cta{display:flex;align-items:center;gap:10px}
.btn-ghost{padding:11px 18px;border-radius:999px;border:1px solid var(--line);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);transition:all .2s}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--sheet)}
.btn-cta{padding:14px 22px;border-radius:999px;background:var(--ink);color:var(--sheet);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12px;letter-spacing:.06em;text-transform:uppercase;display:inline-flex;align-items:center;gap:10px;box-shadow:0 12px 26px rgba(20,20,20,.18);transition:background .25s,box-shadow .25s}
.btn-cta:hover{background:var(--orange);box-shadow:0 18px 36px rgba(255,125,47,.32)}

/* ─── Footer ─── */
.footer{background:var(--ink);color:var(--sheet);padding:0 32px 32px;border-top:1px solid rgba(255,255,255,.08)}
.footer-grid{max-width:1320px;margin:0 auto;padding:80px 0 48px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:40px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-col h5{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4);margin:0 0 16px}
.footer-col a{display:block;padding:6px 0;font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:14px;color:rgba(255,255,255,.78);transition:color .2s,padding .2s}
.footer-col a:hover{color:var(--orange);padding-left:6px}
.footer-brand p{margin:16px 0 24px;font-size:13.5px;color:rgba(255,255,255,.6);line-height:1.55;max-width:280px}
.footer-brand .fb-logo{height:28px;width:auto}
.footer-brand .fb-logo path{fill:var(--paper)}
.footer-socials{display:flex;gap:8px;margin-top:8px}
.footer-socials a{width:42px;height:42px;border-radius:999px;border:1px solid rgba(255,255,255,.16);display:grid;place-items:center;font-size:16px;padding:0;transition:all .2s}
.footer-socials a:hover{background:var(--orange);border-color:var(--orange);padding:0}
.footer-mark-wrap{max-width:1600px;margin:48px auto 0;position:relative;padding:0 8px;overflow:hidden}
.footer-mark{width:100%;height:auto;display:block}
.footer-mark path{fill:transparent;stroke:rgba(248,246,239,.32);stroke-width:.5;transition:fill .35s ease,stroke .35s}
.footer-bot{max-width:1320px;margin:0 auto;padding-top:24px;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(255,255,255,.45);letter-spacing:.05em}
.footer-bot .l{display:flex;gap:18px}

/* ─── Word spacing fix: tight negative letter-spacing at large sizes compresses the space character ─── */
h1,h2{word-spacing:0.1em}

/* ─── Mobile nav ─── */
.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;border-radius:999px;border:1.5px solid var(--line);padding:0;align-items:center;cursor:pointer;transition:background .2s,border-color .2s}
.nav-hamburger:hover{background:var(--ink);border-color:var(--ink)}
.nav-hamburger:hover .hb{background:var(--sheet)}
.hb{width:18px;height:2px;border-radius:1px;background:var(--ink);transition:all .3s cubic-bezier(.2,.8,.2,1)}
.nav-hamburger.open .hb:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open .hb:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.open .hb:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-hamburger.open{background:var(--ink);border-color:var(--ink)}
.nav-hamburger.open .hb{background:var(--sheet)}

.mobile-nav{
  display:none;position:fixed;top:80px;left:0;right:0;
  background:rgba(236,233,223,.97);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);
  border-bottom:1px solid var(--line);z-index:79;
  padding:16px 24px 24px;
  transform:translateY(-8px);opacity:0;pointer-events:none;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),opacity .3s;
}
.mobile-nav.open{transform:translateY(0);opacity:1;pointer-events:auto}
.mobile-nav a{
  display:block;padding:14px 16px;border-radius:14px;
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:18px;
  letter-spacing:.03em;text-transform:uppercase;color:var(--ink);
  transition:background .2s,color .2s;
}
.mobile-nav a:hover,.mobile-nav a.active{background:var(--ink);color:var(--sheet)}
.mobile-nav .mob-cta{
  margin-top:12px;padding-top:16px;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:10px;
}
.mobile-nav .mob-cta a{
  text-align:center;padding:16px;border-radius:999px;
  font-size:14px;letter-spacing:.06em;
}
.mobile-nav .mob-cta .btn-ghost-mob{border:1.5px solid var(--line)}
.mobile-nav .mob-cta .btn-cta-mob{background:var(--ink);color:var(--sheet);display:flex;align-items:center;justify-content:center;gap:10px}
.mobile-nav .mob-cta .btn-cta-mob:hover{background:var(--orange)}

/* ─── Common responsive ─── */
@media (max-width:1180px){
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr}
}
@media (max-width:900px){
  body{cursor:auto}
  .cursor,.cursor-dot{display:none}
  .nav-links{display:none}
  /* Hide CTA buttons but keep .nav-cta container so the theme-toggle button stays visible */
  .nav-cta .btn-ghost,.nav-cta .btn-cta{display:none}
  .nav-hamburger{display:inline-flex}
  .mobile-nav{display:block}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:600px){
  .footer-grid{grid-template-columns:1fr}
}
