/* Minimal homepage: ONLY 4 envelope "folders" side-by-side.
   Hover: envelope opens + multiple thumbnails pop out & bounce.
   Click: opens separate detail page.
   (Pixelwrld-inspired interaction pattern, original implementation.)
*/
:root{
  --bg:#f7f8d8;
  --dot:rgba(18,18,18,.085);
  --ink:#0f0f10;
  --muted:rgba(15,15,16,.62);
  --stroke:rgba(15,15,16,.14);
  --stroke2:rgba(15,15,16,.08);
  --accent:#146665;
  --accent-soft:#4d8c8a;
  --shadow:0 18px 60px rgba(0,0,0,.12);
  --shadow2:0 10px 30px rgba(0,0,0,.10);
  --spring:cubic-bezier(.16, 1, .3, 1);
  --ease:cubic-bezier(.2,.8,.2,1);
  --max:1080px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: "Inconsolata", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  color:var(--ink);
  background:var(--bg);
  overflow-x:hidden;
}
body.about-page{
  background:var(--bg);
}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
.footer a:hover{color:var(--accent)}
img{display:block;max-width:100%}
::selection{background:rgba(0,0,0,.08)}

/* dotted paper */
.bg-dots{
  position:fixed;inset:0;pointer-events:none;
  background-image: radial-gradient(var(--dot) 1.2px, transparent 1.2px);
  background-size:22px 22px;background-position:2px 2px;
  z-index:-3;
  display:block;
}
.bg-paper{
  position:fixed;
  inset:0;
  pointer-events:none;
  background: url("./assets/Paper texure.jpeg") center/cover no-repeat;
  mix-blend-mode: multiply;
  opacity: .28;
  z-index:-2;
}
/* vignette */
.bg-vignette{
  position:fixed;inset:-120px;pointer-events:none;z-index:-2;
  background:
    radial-gradient(closest-side at 50% 0%, rgba(0,0,0,.06), rgba(0,0,0,0) 72%),
    radial-gradient(closest-side at 50% 120%, rgba(0,0,0,.07), rgba(0,0,0,0) 72%);
  opacity:.55;
}
.bg-elements{
  position:absolute;
  left:0;
  right:0;
  top:0;
  bottom:0;
  pointer-events:none;
  z-index:-1;
}
.bg-ele{
  position:absolute;
  width: clamp(90px, 14vw, 180px);
  height:auto;
  opacity: .22;
  filter: saturate(0.9);
}
.bg-ele1{left:6%; top:6%; transform: rotate(-12deg);}
.bg-ele2{right:8%; top:16%; transform: rotate(10deg);}
.bg-ele3{left:4%; bottom:6%; transform: rotate(-6deg);}
.bg-ele4{right:12%; bottom:6%; transform: rotate(8deg);}
@media (max-width: 700px){
  .bg-ele{width: clamp(90px, 26vw, 160px); opacity:.18;}
  .bg-ele1{left:4%; top:28%;}
  .bg-ele2{right:4%; top:28%;}
  .bg-ele3{left:2%; bottom:8%;}
  .bg-ele4{right:8%; bottom:8%;}
}
@media (max-width: 1024px) and (min-width: 701px){
  .bg-ele1{left:14%; top:6%;}
  .bg-ele2{right:16%; top:12%;}
  .bg-ele3{left:12%; bottom:10%;}
  .bg-ele4{right:14%; bottom:10%;}
}
.focus-overlay{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.0);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  opacity:0;
  pointer-events:none;
  transition: opacity .25s var(--spring);
  z-index:1;
}
.corner-note{
  position:absolute;
  top: 36px;
  left: 50%;
  font-family: "Gloria Hallelujah", "Comic Sans MS", cursive;
  font-size: 26px;
  line-height:1.15;
  color: var(--accent);
  text-align:center;
  text-wrap: balance;
  transform: translateX(-50%) rotate(-3deg);
  z-index:2;
  pointer-events:none;
}
@media (max-width: 700px){
  .corner-note{
    top: 18px;
    left: 50%;
    font-size: 20px;
  }
  .comma-break::after{
    content:"";
    display:block;
  }
  .line-break-after::after{
    content:"";
    display:block;
  }
  .bio-line{
    display:block;
    white-space: normal;
  }
  .bio-rotator{
    display:block;
    margin-top: 2px;
  }
  .stage{
    padding: 40px clamp(16px, 5vw, 40px) 44px;
  }
  .bio{
    width:min(520px, calc(100% - 34px));
  }
}
@media (max-width: 1200px) and (min-width: 701px){
  .corner-note{
    top: 28px;
  }
  .stage{
    padding: 180px clamp(30px, 5vw, 90px) 44px;
  }
}
@media (max-width: 900px){
  .stage{
    padding: 60px clamp(16px, 5vw, 40px) 44px;
  }
}

.container{width:min(var(--max), calc(100% - 34px)); margin:0 auto;}

.stage{
  min-height:100vh;
  min-height:100svh;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding: 120px clamp(30px, 5vw, 120px) 44px;
}
@media (min-width: 1201px){
  .stage{
    padding: 200px clamp(30px, 5vw, 120px) 44px;
  }
}

.bio{
  width:min(560px, calc(100% - 34px));
  text-align:center;
  font-size: 18px;
  color: rgba(0,0,0,.6);
  margin-bottom: 22px;
  text-wrap: balance;
}
.bio-line{
  display:inline-block;
  white-space: nowrap;
}
.bio-name{
  font-weight: 700;
  color: var(--accent);
}
.bio-rotator{
  display:inline-block;
  white-space: nowrap;
}
.bio-rotator-word{
  display:inline-block;
  transition: opacity .25s var(--spring), transform .25s var(--spring);
  text-decoration: underline;
  text-underline-offset: 3px;
  white-space: nowrap;
}
.bio-break{
  display:block;
}
.bio-sentence{
  display:block;
  text-wrap: balance;
}
@media (min-width: 701px){
  .desktop-comma-break::after{
    content:"";
    display:block;
  }
}
.bio-rotator-word.is-hidden{
  opacity:0;
  transform: translateY(6px);
}

.grid{
  width:min(920px, calc(100% - 34px));
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 34px;
  align-items:end;
  justify-items:center;
}
@media (max-width: 1200px) and (min-width: 801px){
  .corner-note{
    top: 28px;
  }
  .stage{
    padding: 190px 0 44px;
  }
  .bio{
    font-size: clamp(16px, 1.6vw, 18px);
    width:min(540px, calc(100% - 34px));
  }
  .grid{
    width:min(900px, calc(100% - 34px));
    gap: 26px;
  }
  .folder{
    width: clamp(150px, 17vw, 170px);
  }
  .avatar{
    width: clamp(115px, 13vw, 130px);
    height: clamp(115px, 13vw, 130px);
  }
}
@media (max-width: 720px){
  .grid{row-gap: 2px;}
  .grid .profile{order:-1; grid-column:1 / -1;}
  .grid{margin-top: -10px;}
  .grid{justify-content:center;}
  .folder{width:140px;}
  .bio{width:min(480px, calc(100% - 34px));}
}
@media (max-width: 600px){
  .grid{grid-template-columns: 1fr; row-gap: 6px;}
  .grid .profile{order:-1; grid-column:1 / -1;}
  .grid{justify-items:center;}
  .folder{width:min(220px, 70vw);}
  .profile .hover-meta{
    transform: translate(-50%, -4px);
    padding-top: 6px;
  }
  .profile:hover .hover-meta,
  .profile:focus-within .hover-meta{
    transform: translate(-50%, 2px);
  }
  .profile .peek{
    top: -40px !important;
  }
  .folder:first-child .thumb{
    transform: translate(var(--x0, 0px), var(--y0, 18px)) rotate(var(--r, 0deg)) scale(.6);
  }
}
@media (max-width: 520px){
  .grid{gap: 14px;}
  .folder{width:120px;}
}

/* envelope tile */
.folder{
  position:relative;
  width: 170px;
  padding: 10px 10px 14px;
  border-radius: 28px;
  border: 0;
  background: transparent;
  box-shadow: none;
  transition: transform .28s var(--spring), box-shadow .28s var(--spring), filter .28s var(--spring);
  transform: translate3d(0,0,0);
  will-change: transform;
  display:grid;
  justify-items:center;
  gap: 12px;
  z-index:0;
  transform-origin: center;
}
.folder:hover{
  transform: translateY(-4px) scale(1);
  box-shadow: none;
  filter:saturate(1.03);
}
.graphic-folder{
  margin-bottom: 18px;
}
.folder:active{transform: translateY(-2px) scale(.995);}

.avatar{
  width: 130px;
  height: 130px;
  border-radius: 999px;
  overflow:hidden;
  background: rgba(0,0,0,.06);
  display:grid;
  place-items:center;
  position:relative;
  z-index:6;
  transition: opacity .2s var(--spring), transform .35s var(--spring);
}
.avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position: center;
  transition: opacity .2s var(--spring), transform .35s var(--spring);
  transform: scale(1.22);
}
.folder:hover .avatar{opacity:0; transform: scale(.96);}

.env{
  position:relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  display:grid;
  place-items:center;
  z-index:6;
  transform: translateY(36px);
  transition: transform .45s var(--spring);
}
.env .closed{
  width: 92%;
  height: 92%;
  object-fit: contain;
  opacity:1;
  transform: translateY(2px);
  transition: opacity .18s var(--spring);
}
.env .open{
  position:absolute; inset:0;
  display:grid; place-items:center;
  opacity:0;
  transform: translateY(12px) rotate(-2deg) scale(.98);
  transform-origin: 50% 62%;
  transition: opacity .22s var(--spring), transform .22s var(--spring);
}
.env .open img{
  width: 92%;
  height: 92%;
  object-fit: contain;
}

.folder:hover .env .open{opacity:1; transform: translateY(-6px) rotate(0deg) scale(1);}
.folder:hover .env .closed{opacity:0;}
.folder:hover .env{animation: env-bounce 1.4s var(--spring) both;}

.hover-copy{
  font-size: 12px;
  letter-spacing: .01em;
  color: rgba(0,0,0,.52);
  line-height:1.4;
  text-align:center;
  max-width: 210px;
  text-wrap: balance;
}

@keyframes env-bounce{
  0%{transform: translateY(36px) scale(1);}
  60%{transform: translateY(42px) scale(.985);}
  85%{transform: translateY(40px) scale(.99);}
  100%{transform: translateY(42px) scale(.90);}
}

.pill{
  padding: 10px 24px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: #f4fffe;
  font-weight: 650;
  font-size: 14px;
  line-height:1;
  min-width: 180px;
  text-align:center;
  transition: transform .22s var(--spring), background .22s var(--spring);
}
.hover-meta{
  position:absolute;
  left:50%;
  top:100%;
  transform: translate(-50%, 6px);
  width: 230px;
  display:grid;
  gap: 8px;
  justify-items:center;
  opacity:0;
  pointer-events:none;
  transition: transform .25s var(--spring), opacity .2s var(--spring);
  padding-top: 14px;
}
.hover-meta::before{
  content:"";
  position:absolute;
  left:50%;
  top:-18px;
  width: 260px;
  height: 32px;
  transform: translateX(-50%);
}
.folder:hover .hover-meta,
.folder:focus-within .hover-meta{
  opacity:1;
  transform: translate(-50%, 12px);
  pointer-events:auto;
}
.folder:hover .pill{background: var(--accent);}
.pill .label-hover{display:none;}
.folder:hover .pill .label-default{display:none;}
.folder:hover .pill .label-hover{display:inline;}

/* pop-out thumbnails */
.peek{
  position:absolute;
  left:50%;
  top:-170px;
  transform: translateX(-50%) translate(var(--peek-x, 0px), var(--peek-y, 0px));
  width: 280px;
  height: 220px;
  pointer-events:none;
  opacity:0;
  transition: opacity .16s var(--spring);
  filter: drop-shadow(0 18px 34px rgba(0,0,0,.14));
  z-index:5;
}
.folder:hover .peek{opacity:1;}
.profile .peek{
  top:-150px;
  width: 240px;
  height: 200px;
}

.thumb{
  position:absolute;
  width: min(calc(var(--w, 138px) * 1.18), 34vw);
  height: min(calc(var(--h, 96px) * 1.18), 26vw);
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.10);
  background: #f3f3f3;
  box-shadow: var(--shadow);
  overflow:hidden;
  transform-origin:center;
  opacity:0;
  will-change: transform, opacity;
  transition: transform .35s var(--spring);
}
.thumb img{width:100%;height:100%;object-fit:cover;border-radius:inherit}
.me2-thumb{
  border-radius: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  overflow: visible;
}
.me2-thumb img{
  object-fit: contain;
}
.lp2-thumb{
  border-radius: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  overflow: visible;
}
.lp2-thumb img{
  object-fit: contain;
}
.clear-thumb{
  border-radius: 14px;
  background: transparent;
  border: 0;
  box-shadow: none;
  overflow: hidden;
}
.clear-thumb img{
  object-fit: contain;
}
.icon-thumb{
  z-index: 3;
}
.top-thumb{
  z-index: 3;
}

/* start positions hidden */
.thumb{transform: translate(var(--x0, 0px), var(--y0, 18px)) rotate(var(--r, 0deg)) scale(.72);}

/* on hover: stagger pop + bounce */
.folder:hover .t1{opacity:1; animation: pop1 1.1s var(--spring) both;}
.folder:hover .t2{opacity:1; animation: pop2 1.1s var(--spring) both .06s;}
.folder:hover .t3{opacity:1; animation: pop3 1.1s var(--spring) both .12s;}
.folder:hover .t4{opacity:1; animation: pop4 1.1s var(--spring) both .18s;}
.folder:hover .t5{opacity:1; animation: pop5 1.1s var(--spring) both .24s;}
.folder:hover .t6{opacity:1; animation: pop6 1.1s var(--spring) both .30s;}
.folder:hover .t7{opacity:1; animation: pop7 1.1s var(--spring) both .36s;}
.folder:hover .t8{opacity:1; animation: pop8 1.1s var(--spring) both .42s;}
body.focus-mode .folder:hover .t1{animation: pop1-focus 1.1s var(--spring) both;}
body.focus-mode .folder:hover .t2{animation: pop2-focus 1.1s var(--spring) both .06s;}
body.focus-mode .folder:hover .t3{animation: pop3-focus 1.1s var(--spring) both .12s;}
body.focus-mode .folder:hover .t4{animation: pop4-focus 1.1s var(--spring) both .18s;}
body.focus-mode .folder:hover .t5{animation: pop5-focus 1.1s var(--spring) both .24s;}
body.focus-mode .folder:hover .t6{animation: pop6-focus 1.1s var(--spring) both .30s;}
body.focus-mode .folder:hover .t7{animation: pop7-focus 1.1s var(--spring) both .36s;}
body.focus-mode .folder:hover .t8{animation: pop8-focus 1.1s var(--spring) both .42s;}

body.focus-mode .focus-overlay{opacity:1;}
body.focus-mode .folder:hover{
  filter: none;
}
body.focus-mode .folder:hover,
body.focus-mode .folder:hover .peek{
  filter: none;
}
body.focus-mode .folder:hover{
  z-index:4;
}
body.focus-mode .folder:hover .peek{
  opacity:1;
  transform: translateX(-50%) translate(var(--peek-x, 0px), var(--peek-y, 0px)) scale(1.12);
}

@keyframes pop1{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.72)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.12)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.08)}
}
@keyframes pop2{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.70)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.14)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.10)}
}
@keyframes pop3{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.68)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.10)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.06)}
}
@keyframes pop4{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.68)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.08)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.04)}
}
@keyframes pop5{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.68)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.10)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.06)}
}
@keyframes pop6{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.66)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.06)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.02)}
}
@keyframes pop7{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.66)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.06)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.02)}
}
@keyframes pop8{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.66)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.06)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.02)}
}
@keyframes pop1-focus{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.76)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.22)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.18)}
}
@keyframes pop2-focus{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.74)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.24)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.20)}
}
@keyframes pop3-focus{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.72)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.20)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.16)}
}
@keyframes pop4-focus{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.72)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.18)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.14)}
}
@keyframes pop5-focus{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.72)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.20)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.16)}
}
@keyframes pop6-focus{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.70)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.16)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.12)}
}
@keyframes pop7-focus{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.70)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.16)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.12)}
}
@keyframes pop8-focus{
  0%{transform: translate(var(--x0), var(--y0)) rotate(var(--r)) scale(.70)}
  64%{transform: translate(var(--x1), var(--y1)) rotate(calc(var(--r) * .7)) scale(1.16)}
  100%{transform: translate(var(--x2), var(--y2)) rotate(calc(var(--r) * .7)) scale(1.12)}
}
@keyframes bob1{0%,100%{translate:0 0}50%{translate:0 0}}
@keyframes bob2{0%,100%{translate:0 0}50%{translate:0 0}}
@keyframes bob3{0%,100%{translate:0 0}50%{translate:0 0}}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important}
}

/* detail pages (simple) */
.detail{
  width:min(980px, calc(100% - 34px));
  margin:0 auto;
  padding: 18px 0 60px;
}
.h1{
  font-family: "Inconsolata", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: clamp(34px, 4vw, 54px);
  margin: 12px 0 8px;
  letter-spacing:-.35px;
}
.p{
  color:var(--muted);
  line-height:1.85;
  max-width: 84ch;
  margin:0 0 18px;
}
.back{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 14px;border-radius:999px;
  background: rgba(0,0,0,.06);
  border: 1px solid rgba(0,0,0,.04);
  font-weight:700;font-size:13px;
  position: relative;
  z-index: 2;
}
.back-overlay{
  position:fixed;
  top:22px;
  left:22px;
  background: rgba(255,255,255,.85);
  border-color: rgba(0,0,0,.08);
  z-index:5;
}
.about-full{
  width:100%;
  height:100vh;
  height:100svh;
  object-fit:cover;
  display:block;
}
.panel{
  border:1px solid rgba(0,0,0,.06);
  background:#fff;
  border-radius: 34px;
  box-shadow: var(--shadow2);
  padding: 18px;
  margin-top:14px;
}
.about-wrap{
  width:min(1100px, calc(100% - 34px));
  margin:0 auto;
  padding: 90px 0 160px;
  display:grid;
  gap: 28px;
}
.about-hero{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 24px;
  align-items:center;
}
.about-copy{
  display:grid;
  gap: 14px;
}
.about-kicker{
  font-size: 12px;
  letter-spacing:.18em;
  text-transform: uppercase;
  color: rgba(0,0,0,.45);
}
.about-hero h1{
  margin:0;
  font-size: clamp(32px, 4.4vw, 52px);
}
.name-nowrap{
  white-space: nowrap;
}
.about-lede{
  margin:0;
  color: rgba(0,0,0,.6);
  line-height:1.4;
  text-wrap: balance;
}
.about-note{
  margin:0;
  font-weight:700;
  color: var(--accent);
  text-wrap: balance;
}
.about-bubble{
  width: fit-content;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(20,102,101,.12);
  color: var(--accent);
  font-size: 13px;
}
.about-visual{
  position:relative;
  display:grid;
  place-items:center;
  padding: 18px;
}
.about-visual img{
  width:min(380px, 80vw);
  height:auto;
  transform: rotate(-2deg);
  filter: drop-shadow(0 18px 30px rgba(0,0,0,.18));
}
.about-spark{
  position:absolute;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  background: rgba(20,102,101,.2);
  transform: translate(120px, -120px) rotate(18deg);
  animation: spark-float 3s ease-in-out infinite;
}
.about-panels{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 18px;
}
.about-panel{
  background: #fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius: 26px;
  padding: 18px;
  box-shadow: var(--shadow2);
  transition: transform .25s var(--spring), box-shadow .25s var(--spring);
}
.about-panel:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow);
}
.chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom: 10px;
}
.chip{
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.04);
  font-size: 12px;
}
.timeline{
  display:grid;
  gap: 12px;
}
.timeline-item{
  border-left: 2px solid rgba(20,102,101,.2);
  padding-left: 10px;
}
.timeline-year{
  font-size: 12px;
  color: rgba(0,0,0,.45);
}
.timeline-title{
  font-weight: 700;
}
.timeline-meta{
  color: rgba(0,0,0,.55);
  font-size: 13px;
}
.about-details{
  margin-top: 12px;
}
.about-details summary{
  cursor:pointer;
  font-weight:700;
}
.about-details p{
  margin:8px 0 0;
  color: rgba(0,0,0,.6);
  line-height:1.6;
}
.about-details-title{
  font-weight:700;
}
@keyframes ring-spin{
  to{transform: rotate(360deg);}
}
@keyframes spark-float{
  0%,100%{transform: translate(120px, -120px) rotate(18deg);}
  50%{transform: translate(130px, -110px) rotate(-6deg);}
}
@media (max-width: 900px){
  .about-hero{grid-template-columns:1fr;}
  .about-panels{grid-template-columns:1fr;}
  .about-wrap{padding: 80px 0 140px;}
}
.fun-facts{
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius: 28px;
  padding: 18px;
  box-shadow: var(--shadow2);
}
.facts-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom: 12px;
  font-size: 13px;
  color: rgba(0,0,0,.55);
}
.facts-title{
  font-weight: 700;
  letter-spacing:.02em;
}
.facts-card{
  position:relative;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(0,0,0,.02), rgba(0,0,0,.01));
  border:1px solid rgba(0,0,0,.06);
  padding: 28px 54px;
  min-height: 160px;
  display:grid;
  align-items:end;
  overflow:hidden;
}
.facts-text{
  font-size: 18px;
  line-height:1.6;
  color: rgba(0,0,0,.72);
  transition: opacity .25s var(--spring), transform .25s var(--spring);
  text-wrap: balance;
}
.facts-text.is-exit{
  opacity:0;
  transform: translateY(6px);
}
.facts-text.is-enter{
  opacity:1;
  transform: translateY(0);
}
.facts-arrow{
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  width:34px;
  height:34px;
  border-radius:50%;
  border:0;
  background:#fff;
  box-shadow: 0 6px 14px rgba(0,0,0,.12);
  cursor:pointer;
  font-size:18px;
  display:grid;
  place-items:center;
}
.facts-arrow.left{left:12px;}
.facts-arrow.right{right:12px;}
.grid2{display:grid;grid-template-columns:1.2fr .8fr;gap:12px;align-items:start}
@media (max-width: 900px){ .grid2{grid-template-columns:1fr} }
.ph{
  border:1px solid rgba(0,0,0,.06);
  background: linear-gradient(135deg, rgba(0,0,0,.03), rgba(0,0,0,.01));
  border-radius: 22px;
  height: 260px;
  display:grid;place-items:center;
  color: rgba(0,0,0,.55);
  font-weight:800;
}
.ph.small{height:160px;border-radius:20px}
.footer{
  width:100%;
  margin-top: auto;
  padding: 12px 0;
  padding-left: 20%;
  padding-right: 20%;
  color: rgba(0,0,0,.55);
  font-size: 18px;
  background: transparent;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px;
  text-wrap: balance;
}
body.about-page .footer{
  font-size: 18px;
}
@media (max-width: 900px){
  .footer{
    padding-left: 8%;
    padding-right: 8%;
    justify-content:center;
  }
  .footer > div{
    width:100%;
    text-align:center;
  }
}
@media (min-width: 1200px){
  .bio{
    width:min(820px, calc(100% - 96px));
    font-size: 20px;
  }
  .grid{width:min(1180px, calc(100% - 96px)); gap: 44px;}
  .folder{width: 200px;}
  .avatar{width: 150px; height: 150px;}
  .corner-note{font-size: 28px;}
  .footer{font-size: 20px;}
}
@media (min-width: 901px){
  .bio{
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media (min-width: 1500px){
  .bio{
    width:min(920px, calc(100% - 140px));
    font-size: 22px;
  }
  .grid{width:min(1300px, calc(100% - 140px)); gap: 48px;}
  .folder{width: 220px;}
  .avatar{width: 165px; height: 165px;}
  .footer{font-size: 22px;}
}

.ideas-rotator-wrap{
  position:relative;
  margin-top: 6px;
  height: min(100vh, 720px);
  height: min(100svh, 720px);
  width: min(100vw, 1200px);
  margin-left: auto;
  margin-right: auto;
}
.ideas-intro{
  margin-bottom: 6px;
}
.ideas-rotator{
  width: 100%;
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  transform: rotate(-90deg) translateX(-100%);
  transform-origin: top left;
}
.ideas-rotator::-webkit-scrollbar{
  width: 10px;
}
.ideas-rotator::-webkit-scrollbar-thumb{
  background: rgba(20,102,101,.3);
  border-radius: 999px;
}
.ideas-track{
  display:flex;
  gap: 18px;
  padding: 12px 18px 12px 12px;
  transform: rotate(90deg) translateY(-100%);
  transform-origin: top left;
}
.ideas-track .idea-card{
  width: 420px;
  flex: 0 0 auto;
}
@media (max-width: 820px){
  .ideas-rotator-wrap{
    height: min(100vh, 560px);
    height: min(100svh, 560px);
    width: min(100vw, 520px);
  }
  .ideas-track .idea-card{
    width: 320px;
  }
}
.idea-card{
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  border-radius: 26px;
  padding: 16px;
  box-shadow: var(--shadow2);
}
.idea-media{
  height: 240px;
  border-radius: 18px;
  border: 1px dashed rgba(20,102,101,.3);
  background: linear-gradient(135deg, rgba(20,102,101,.08), rgba(20,102,101,.02));
  display:grid;
  place-items:center;
  color: var(--accent);
  font-weight: 700;
  letter-spacing: .02em;
}
.idea-title{
  margin: 12px 0 4px;
  font-size: 18px;
}
.idea-meta{
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}
