/* -----------------------------------------
   NOOTO FOLIO / PORTFOLIO THEME
   Desktop only
----------------------------------------- */

@media (min-width:1200px){

/* -----------------------------------------
   1. Theme Variables
----------------------------------------- */

body[data-site-theme="portfolio"]{
  --folio-bg:#070707;
  --folio-panel:#101010;
  --folio-text:#f7f5ef;
  --folio-muted:rgba(247,245,239,.62);
  --folio-line:rgba(247,245,239,.16);

  --nooto-action-bg:#f7f5ef;
  --nooto-action-text:#111;
  --nooto-action-border:rgba(255,255,255,.18);
  --nooto-action-shadow:0 12px 34px rgba(0,0,0,.36);

  background:var(--folio-bg);
  color:var(--folio-text);
  scrollbar-color:var(--site-color) var(--folio-bg);
}

/* -----------------------------------------
   2. Base / Scrollbar
----------------------------------------- */

body[data-site-theme="portfolio"]::-webkit-scrollbar{
  width:12px;
  background:var(--folio-bg);
}

body[data-site-theme="portfolio"]::-webkit-scrollbar-track{
  background:var(--folio-bg);
}

body[data-site-theme="portfolio"]::-webkit-scrollbar-thumb{
  background:var(--site-color);
}

body[data-site-theme="portfolio"] .wrap{
  display:block;
  max-width:none;
  padding:0;
}

body[data-site-theme="portfolio"] main,
body[data-site-theme="portfolio"] .site-nav,
body[data-site-theme="portfolio"] .NootoDialog{
  background:var(--folio-bg);
}

body[data-site-theme="portfolio"] .NootoSection img,
body[data-site-theme="portfolio"] .NootoCardCover img{
  background:#dcdcdc;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.05);
}



/* -----------------------------------------
   3. Header
----------------------------------------- */

body[data-site-theme="portfolio"] .site-nav{
  position:sticky;
  top:0;
  z-index:2000;
  width:min(1180px, calc(100% - 96px));
  height:auto;
  min-height:0;
  margin:0 auto;
  padding:15px 0 0;
  border:0;
  border-radius:0;
  box-shadow:none;
}

body[data-site-theme="portfolio"] .MenuButton{
  display:none;
}

body[data-site-theme="portfolio"] .NootoDialog{
  position:static;
  display:block;
  width:100%;
  height:auto;
  min-height:0;
  max-width:none;
  margin:0;
  padding:0;
  border:0;
  border-radius:0;
  color:var(--folio-text);
  box-shadow:none;
  overflow:visible;
}

body[data-site-theme="portfolio"] .NootoDialogHead{
  display:none;
}

body[data-site-theme="portfolio"] .nav-links{
  display:flex;
  align-items:center;
  gap:23px;
  width:100%;
  min-height:64px;
  margin:0;
  padding:0;
  overflow:hidden;
  white-space:nowrap;
}

body[data-site-theme="portfolio"] .nav-links > a:first-child,
body[data-site-theme="portfolio"] .NootoSystemAlert,
body[data-site-theme="portfolio"] .NootoSearchWrap,
body[data-site-theme="portfolio"] .NootoEditLink,
body[data-site-theme="portfolio"] .NootoNavQR,
body[data-site-theme="portfolio"] .nav-links > br{
  display:none !important;
}

body[data-site-theme="portfolio"] .NootoDesktopTitle{
  display:flex;
  align-items:center;
  margin-right:auto;
  min-height:64px;
  color:var(--site-color);
  font-size:1.50rem !important;
  font-weight:700;
  line-height:1;
  letter-spacing:-.02em;
  text-decoration:none;
  border:0;
  opacity:1;
}

body[data-site-theme="portfolio"] .NootoDesktopTitle img{
  display:block;
  max-height:50px;
  width:auto;
  object-fit:contain;
  border-radius:0 !important;
}

body[data-site-theme="portfolio"] .NootoNavLink{
  display:flex;
  align-items:center;
  min-height:64px;
  color:var(--site-color);
  font-size:.95rem;
  font-weight:600;
  line-height:1;
  text-decoration:none;
  border-bottom:1px solid transparent;
  opacity:.95;
}

body[data-site-theme="portfolio"] .NootoNavLink:hover,
body[data-site-theme="portfolio"] .NootoNavLink.Active{
  color:var(--site-color);
  opacity:1;
  border-bottom-color:currentColor;
}

body[data-site-theme="portfolio"] .NootoNavLink.Active{
  font-weight:700;
}

/* -----------------------------------------
   4. Compact Header / Modal Menu
----------------------------------------- */

body[data-site-theme="portfolio"] .NootoDialog[open]{
  overflow-y:auto;
  overflow-x:hidden;
  scrollbar-width:none;
}

body[data-site-theme="portfolio"] .NootoDialog[open]::-webkit-scrollbar{
  width:0;
  height:0;
}



body[data-site-theme="portfolio"].FolioCompact .MenuButton{
  display:flex;
  align-items:center;
  justify-content:space-between;
  width:100%;
  height:44px;
  margin:0;
  padding:0;
  border:0;
  background:transparent;
  color:var(--site-color);
}

body[data-site-theme="portfolio"].FolioCompact .MenuButtonTitle{
  font-size:1.12rem;
  font-weight:600;
  line-height:1;
}

body[data-site-theme="portfolio"].FolioCompact .MenuButtonIcon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  margin-right:-10px;
  color:var(--site-color);
  font-size:1.35rem;
  line-height:1;
}

body[data-site-theme="portfolio"].FolioCompact .NootoDialog:not([open]){
  display:none;
}

body[data-site-theme="portfolio"] .NootoDialog[open]{
  position:fixed;
  inset:0;
  z-index:3000;
  display:block;
  width:100%;
  height:100%;
  max-width:none;
  margin:0;
  padding:15px 0 80px;
  background:var(--folio-bg);
  color:var(--folio-text);
  overflow:auto;
}

body[data-site-theme="portfolio"] .NootoDialog[open] .NootoDialogHead{
  display:flex;
  justify-content:flex-end;
  width:min(1180px, calc(100% - 96px));
  height:44px;
  margin:0 auto;
  padding:0;
}

body[data-site-theme="portfolio"] .NootoDialog[open] .NootoDialogHead button{
  display:flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  margin-right:-10px;
  padding:0;
  border:0;
  background:transparent;
  color:var(--site-color);
  font-size:2rem;
  line-height:1;
  cursor:pointer;
}

body[data-site-theme="portfolio"] .NootoDialog[open] .nav-links{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:18px;
  width:min(1180px, calc(100% - 96px));
  margin:70px auto 0;
  overflow:visible;
  white-space:normal;
}

body[data-site-theme="portfolio"] .NootoDialog[open] .NootoDesktopTitle{
  margin:0 0 36px;
  font-size:clamp(2.2rem,5vw,5rem) !important;
}

body[data-site-theme="portfolio"] .NootoDialog[open] .NootoNavLink{
  font-size:clamp(1.8rem,5vw,4rem);
  line-height:.95;
  letter-spacing:-.06em;
}





/* -----------------------------------------
   5. Main Layout
----------------------------------------- */

body[data-site-theme="portfolio"] main{
  width:min(1180px, calc(100% - 96px));
  min-height:0;
  margin:0 auto;
  padding:54px 0 90px;
  background:transparent;
  color:var(--folio-text);
}

body[data-site-theme="portfolio"] section,
body[data-site-theme="portfolio"] .NootoSection{
  max-width:760px;
  min-height:0;
  margin:0 0 96px;
  padding:0;
}

/* -----------------------------------------
   6. Typography
----------------------------------------- */

body[data-site-theme="portfolio"] h1{
  color:var(--folio-text);
  font-size:3rem;
  font-weight:600;
  line-height:1.12;
  letter-spacing:-.045em;
  margin:0 0 52px;
}

body[data-site-theme="portfolio"] h2{
  color:var(--folio-text);
  font-size:2.50rem;
  font-weight:600;
  line-height:1.22;
  letter-spacing:-.035em;
  margin:42px 0 22px;
}

body[data-site-theme="portfolio"] h3{
  color:var(--folio-text);
  font-size:1.35rem;
  font-weight:600;
  line-height:1.25;
  letter-spacing:-.025em;
  margin:34px 0 14px;
}

body[data-site-theme="portfolio"] h4{
  color:var(--folio-text);
  font-size:1.25rem;
  font-weight:400;
  line-height:1.4;
  margin:28px 0 10px;
}

body[data-site-theme="portfolio"] h5{
  color:var(--site-color);
  font-size:1rem;
  font-weight:500;
  line-height:1.4;
  margin:26px 0 10px;
}

body[data-site-theme="portfolio"] h6{
  color:#cc0000;
  font-size:1rem;
  font-weight:500;
  margin:24px 0 8px;
}

body[data-site-theme="portfolio"] p,
body[data-site-theme="portfolio"] li{
  color:var(--folio-text);
  font-size:1.38rem;
  line-height:1.62;
  font-weight:500;
  letter-spacing:-.035em;
}

body[data-site-theme="portfolio"] p{
  margin:0 0 .72em;
}

body[data-site-theme="portfolio"] ul,
body[data-site-theme="portfolio"] ol{
  padding-left:1.25em;
  margin:0 0 1.6em;
}

body[data-site-theme="portfolio"] strong{
  color:#fff;
  font-weight:700;
}

body[data-site-theme="portfolio"] em{
  color:var(--folio-muted);
  font-style:italic;
}

body[data-site-theme="portfolio"] strong em,
body[data-site-theme="portfolio"] em strong{
  color:#fff;
  font-style:italic;
  font-weight:700;
}


/* -----------------------------------------
   Inline Code
----------------------------------------- */

body[data-site-theme="portfolio"] code{
  background:var(--folio-panel);
  color:var(--site-color);

  padding:.12em .42em;
  border-radius:6px;

  font-size:.92em;

  border:1px solid var(--folio-line);
}


body[data-site-theme="portfolio"] pre{
  background:#111;
  color:#fff;
}

body[data-site-theme="portfolio"] pre code{
  background:transparent;
  color:inherit;
  border:0;
  padding:0;
}



/* -----------------------------------------
   7. Links
----------------------------------------- */

body[data-site-theme="portfolio"] a{
  color:var(--site-color);
  text-decoration:none !important;
}

body[data-site-theme="portfolio"] main a:not(.NootoButton):not(.NootoHeroButton):not(.NootoCard):not(.NootoGalleryItem){
  color:var(--folio-text);
  border-bottom:1px solid rgba(247,245,239,.45);
}

body[data-site-theme="portfolio"] main a:not(.NootoButton):not(.NootoHeroButton):not(.NootoCard):not(.NootoGalleryItem):hover{
  color:var(--site-color);
  border-color:var(--site-color);
}






/* -----------------------------------------
   FOLIO MAPS
----------------------------------------- */

body[data-site-theme="portfolio"] main a.MapCard,
body[data-site-theme="portfolio"] main a.MapCard:link,
body[data-site-theme="portfolio"] main a.MapCard:visited,
body[data-site-theme="portfolio"] main a.MapCard:hover{
  background:var(--folio-panel);
  color:var(--folio-text);
  border:1px solid var(--folio-line);
  border-radius:8px;
  text-decoration:none !important;
  box-shadow:0 10px 30px rgba(0,0,0,.28);
}

body[data-site-theme="portfolio"] main a.MapCard:hover{
  border-color:rgba(255,255,255,.28);
}

body[data-site-theme="portfolio"] .MapCard strong{
  color:var(--folio-text);
}

body[data-site-theme="portfolio"] .MapCard small{
  color:var(--folio-muted);
  opacity:1;
}

body[data-site-theme="portfolio"] .MapThumb{
  background:#1a1a1a;
}




/* -----------------------------------------
   8. Standard Action Buttons
----------------------------------------- */

body[data-site-theme="portfolio"] .NootoButton,
body[data-site-theme="portfolio"] .NootoButton:link,
body[data-site-theme="portfolio"] .NootoButton:visited,
body[data-site-theme="portfolio"] .NootoContactForm button,
body[data-site-theme="portfolio"] .NootoContinueReading{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:0 24px;
  border:1px solid var(--nooto-action-border);
  border-radius:10px;
  background:var(--nooto-action-bg);
  color:var(--nooto-action-text);
  font-weight:700;
  font-size:.95rem;
  letter-spacing:.01em;
  text-decoration:none !important;
  box-shadow:var(--nooto-action-shadow);
  transition:.18s ease;
}

body[data-site-theme="portfolio"] .NootoButton:hover,
body[data-site-theme="portfolio"] .NootoContactForm button:hover,
body[data-site-theme="portfolio"] .NootoContinueReading:hover{
  background:#fff;
  color:#111;
  border-color:rgba(255,255,255,.28);
  box-shadow:0 14px 36px rgba(0,0,0,.38);
}

/* -----------------------------------------
   9. Media
----------------------------------------- */

body[data-site-theme="portfolio"] img,
body[data-site-theme="portfolio"] video,
body[data-site-theme="portfolio"] iframe{
  max-width:100%;
  border-radius:5px;
}

body[data-site-theme="portfolio"] figure{
  margin:54px 0;
}

body[data-site-theme="portfolio"] figcaption{
  color:var(--folio-muted);
  font-size:.9rem;
  line-height:1.5;
  margin-top:10px;
}

body[data-site-theme="portfolio"] pre{
  background:#111;
  color:#fff;
}

/* -----------------------------------------
   10. Default Cover 
----------------------------------------- */

body[data-site-theme="portfolio"] .NootoHeroCover{
  width:100%;
  max-width:none;
  margin:0 0 72px;
  aspect-ratio:16/9;
  position:relative;
  overflow:hidden;
  border-radius:10px;
  background: #101010;
}

body[data-site-theme="portfolio"] .NootoHeroCover img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  border-radius:inherit;
}

body[data-site-theme="portfolio"] .NootoSection.NootoIntro{
  max-width:none !important;
}



/* -----------------------------------------
   10.5. HERO
----------------------------------------- */

body[data-site-theme="portfolio"] .NootoHero{
  width:100% !important;
  max-width:none !important;
  border-radius:10px;
  overflow:hidden;
}

body[data-site-theme="portfolio"] .NootoHeroImage{
  display:block;
  width:100%;
  aspect-ratio:21/12;
  height:auto;
  object-fit:cover;
  background-color: #101010;
}

body[data-site-theme="portfolio"] .NootoHeroOverlay{
  padding:40px 56px;
  gap:4px;

}

body[data-site-theme="portfolio"] .NootoHeroOverlay h2{
  margin:0 0 6px 10px;
  color:#fff;
  font-size:clamp(3rem, 5vw, 5.6rem);
  font-weight:900;
  line-height:.88;
  letter-spacing:-.055em;
}

body[data-site-theme="portfolio"] .NootoHeroOverlay p{
  margin:0 0 6px 15px;
  color:#fff;
  font-size:clamp(1.35rem, 2.15vw, 2.25rem);
  font-weight:700;
  line-height:.95;
  letter-spacing:-.035em;
}

body[data-site-theme="portfolio"] .NootoHeroButton,
body[data-site-theme="portfolio"] .NootoHeroButton:link,
body[data-site-theme="portfolio"] .NootoHeroButton:visited{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:58px;
  margin-top:1rem;
  padding:0 28px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  background:var(--folio-bg);
  color:var(--folio-text);
  font-size:1rem;
  font-weight:700;
  letter-spacing:.02em;
  text-decoration:none !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.03),
    0 10px 30px rgba(0,0,0,.45);
  transition:.18s ease;
}

body[data-site-theme="portfolio"] .NootoHeroButton:hover{
  transform:translateY(-2px);
  background:#0d0d0d;
  color:var(--folio-text);
  border-color:rgba(255,255,255,.28);
  box-shadow:
    0 0 24px color-mix(in srgb, var(--site-color) 20%, transparent),
    0 18px 48px rgba(0,0,0,.65);
}

/* -----------------------------------------
   11. Markdown Blocks
----------------------------------------- */

body[data-site-theme="portfolio"] blockquote{
  margin:54px 0;
  padding:0 0 0 22px;
  border-left:1px solid var(--site-color);
}

body[data-site-theme="portfolio"] blockquote p{
  color:var(--folio-text);
  font-size:1.55rem;
  line-height:1.45;
}

body[data-site-theme="portfolio"] hr{
  border:0;
  border-top:1px solid var(--folio-line);
  margin:56px 0;
}

body[data-site-theme="portfolio"] table{
  display:block;
  width:100%;
  overflow-x:auto;
  border-collapse:collapse;
  margin:36px 0;
}

body[data-site-theme="portfolio"] th,
body[data-site-theme="portfolio"] td{
  padding:12px 14px;
  border-bottom:1px solid var(--folio-line);
  color:var(--folio-text);
  text-align:left;
  white-space:nowrap;
}

body[data-site-theme="portfolio"] th{
  color:var(--site-color);
  font-weight:600;
}


/* -----------------------------------------
   FOLIO STRIP / BOX
----------------------------------------- */

body[data-site-theme="portfolio"] .NootoBlock{
  color:var(--folio-text);
}

body[data-site-theme="portfolio"] .NootoBlock-strip{
  padding:26px 0;
  border-top:1px solid rgba(247,245,239,.22);
  border-bottom:1px solid rgba(247,245,239,.22);
}

body[data-site-theme="portfolio"] .NootoBlock-box{
  padding:26px;
  border:1px solid rgba(247,245,239,.22);
  border-radius:14px;
  background:var(--folio-panel);
}


/* -----------------------------------------
   12. TOC
----------------------------------------- */

body[data-site-theme="portfolio"] .NootoTOC{
  background:var(--folio-panel);
  border:1px solid var(--folio-line);
  border-radius:14px;
}

body[data-site-theme="portfolio"] .NootoTOC a{
  color:var(--folio-text);
  border:0;
}

body[data-site-theme="portfolio"] .NootoTOC a:hover{
  color:var(--site-color);
}

body[data-site-theme="portfolio"] .TOCNumber{
  color:var(--folio-muted);
  opacity:1;
}

body[data-site-theme="portfolio"] .TOCText{
  color:inherit;
}

/* -----------------------------------------
   13. Cards
----------------------------------------- */

body[data-site-theme="portfolio"] .NootoSection:has(.NootoCards){
  max-width:none;
}

body[data-site-theme="portfolio"] .NootoCards{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:58px 32px;
  width:100%;
  max-width:none;
}

body[data-site-theme="portfolio"] .NootoCard{
  background:transparent;
  color:inherit;

  border:1px solid var(--folio-line);

  padding:0;
  overflow:hidden;

  box-shadow:none;

  transition:
    transform .22s ease,
    border-color .22s ease,
    box-shadow .22s ease;
}


body[data-site-theme="portfolio"] .NootoCard:hover{
  border-color:rgba(255,255,255,.28);
}

body[data-site-theme="portfolio"] .NootoCard{
  border-radius:5px !important;
}

body[data-site-theme="portfolio"] .NootoCardCover{
  border-radius:5px 5px 0 0 !important;
}

body[data-site-theme="portfolio"] .NootoCardCover img{
  border-radius:5px 5px 0 0 !important;
}

body[data-site-theme="portfolio"] .NootoCardCover{
  width:100%;
  aspect-ratio:1 / 1;
  overflow:hidden;
  background:transparent;
}

body[data-site-theme="portfolio"] .NootoCardCover img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}

body[data-site-theme="portfolio"] .NootoCard h1{
  color:var(--folio-text);
  font-size:1.35rem;
  line-height:1.1;
  margin:0 0 6px;
}

body[data-site-theme="portfolio"] .NootoCard p{
  color:var(--folio-muted);
  font-size:.95rem;
  line-height:1.4;
  margin:0;
}

/* -----------------------------------------
   14. Gallery
----------------------------------------- */

body[data-site-theme="portfolio"] .NootoSection:has(.NootoGallery){
  max-width:none;
}

body[data-site-theme="portfolio"] .NootoGallery{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:58px 32px;
  width:100%;
  max-width:none;
  margin:28px 0 0;
}

body[data-site-theme="portfolio"] .NootoGalleryItem{
  aspect-ratio:1 / 1;
  border-radius:5px;
  background:transparent;
}

body[data-site-theme="portfolio"] .NootoGalleryItem img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:5px;
}


/* -----------------------------------------
   FOLIO TIMELINE
----------------------------------------- */

body[data-site-theme="portfolio"] .NootoTimeline{
  position:relative;
  margin:48px 0;
  padding-left:44px;
}

body[data-site-theme="portfolio"] .NootoTimeline::before{
  content:"";
  position:absolute;

  left:14px;
  top:18px;
  bottom:18px;

  width:1px;

  background:rgba(255,255,255,.12);
}

body[data-site-theme="portfolio"] .NootoTimelineItem{
  position:relative;
  margin:0 0 34px;
}

body[data-site-theme="portfolio"] .NootoTimelineItem::before{
  content:"";
  position:absolute;

  left:-38px;
  top:4px;

  width:14px;
  height:14px;

  border-radius:999px;

  background:var(--folio-bg);
  border:2px solid var(--site-color);

  z-index:2;
}

body[data-site-theme="portfolio"] .NootoTimelineDate{
  margin:0 0 12px;

  color:var(--site-color);

  font-size:.82rem;
  font-weight:700;

  letter-spacing:.08em;
  text-transform:uppercase;

  opacity:.9;
}

body[data-site-theme="portfolio"] .NootoTimelineBody{
  padding:28px;

  background:var(--folio-panel);

  border:1px solid var(--folio-line);
  border-radius:14px;

  box-shadow:none;
}

body[data-site-theme="portfolio"] .NootoTimelineBody h1,
body[data-site-theme="portfolio"] .NootoTimelineBody h2,
body[data-site-theme="portfolio"] .NootoTimelineBody h3{
  color:var(--folio-text);
}

body[data-site-theme="portfolio"] .NootoTimelineBody p{
  color:var(--folio-muted);
}

body[data-site-theme="portfolio"] .NootoTimelineBody > *:first-child{
  margin-top:0;
}

body[data-site-theme="portfolio"] .NootoTimelineBody > *:last-child{
  margin-bottom:0;
}



/* -----------------------------------------
   FOLIO DISCLOSURE
----------------------------------------- */

body[data-site-theme="portfolio"] .NootoDisclosure{
  border-top:1px solid var(--folio-line);
}

body[data-site-theme="portfolio"] .NootoDisclosure:last-child{
  border-bottom:1px solid var(--folio-line);
}

body[data-site-theme="portfolio"] .NootoDisclosure[open]{
  background:var(--folio-panel);
  border:1px solid var(--folio-line);
  border-radius:10px;
}

body[data-site-theme="portfolio"] .NootoDisclosureSummary::after{
  color:var(--site-color);
  opacity:.8;
}

body[data-site-theme="portfolio"] .NootoDisclosureDate{
  color:var(--site-color);
  opacity:.9;
}

body[data-site-theme="portfolio"] .NootoDisclosureSubtitle{
  color:var(--folio-muted);
  opacity:1;
}

body[data-site-theme="portfolio"] .NootoDisclosureBody{
  color:var(--folio-text);
}

body[data-site-theme="portfolio"] .NootoDisclosure[open]{
  margin:8px 0;
}

body[data-site-theme="portfolio"] .NootoDisclosure[open] + .NootoDisclosure{
  border-top:0;
}


/* -----------------------------------------
   15. Footer
----------------------------------------- */

body[data-site-theme="portfolio"] footer,
body[data-site-theme="portfolio"] .NootoFooter{
  width:min(1180px, calc(100% - 96px));
  margin:0 auto;
  padding:42px 0 80px;
  color:var(--folio-text);
  background:transparent;
  border:0;
}

body[data-site-theme="portfolio"] footer,
body[data-site-theme="portfolio"] footer p,
body[data-site-theme="portfolio"] .NootoFooter,
body[data-site-theme="portfolio"] .NootoFooter p{
  font-size:.82rem;
  line-height:1.4;
  font-weight:600;
  letter-spacing:-.02em;
}

body[data-site-theme="portfolio"] footer a,
body[data-site-theme="portfolio"] .NootoFooter a{
  color:var(--folio-text);
  border-bottom:1px solid currentColor;
}






/* -----------------------------------------
   FOLIO TEXT LINKS - FINAL OVERRIDE
----------------------------------------- */

body[data-site-theme="portfolio"] main p a:not(.NootoButton):not(.NootoHeroButton):not(.MapCard),
body[data-site-theme="portfolio"] main li a:not(.NootoButton):not(.NootoHeroButton):not(.MapCard),
body[data-site-theme="portfolio"] main blockquote a:not(.NootoButton):not(.NootoHeroButton):not(.MapCard){
  color:var(--site-color) !important;
  border-bottom:1px solid color-mix(
    in srgb,
    var(--site-color) 55%,
    transparent
  ) !important;
}

body[data-site-theme="portfolio"] main p a:hover,
body[data-site-theme="portfolio"] main li a:hover,
body[data-site-theme="portfolio"] main blockquote a:hover{
  color:var(--site-color) !important;
  border-bottom-color:var(--site-color) !important;
}



/* -----------------------------------------
   FOLIO CONTACT FORM
----------------------------------------- */

body[data-site-theme="portfolio"] .NootoContactForm input,
body[data-site-theme="portfolio"] .NootoContactForm textarea{
  background:var(--folio-panel);
  color:var(--folio-text);

  border:1px solid var(--folio-line);
  border-radius:14px;

  box-shadow:none;
}

body[data-site-theme="portfolio"] .NootoContactForm input:focus,
body[data-site-theme="portfolio"] .NootoContactForm textarea:focus{
  border-color:var(--site-color);
  box-shadow:0 0 0 3px color-mix(
    in srgb,
    var(--site-color) 18%,
    transparent
  );
}

body[data-site-theme="portfolio"] .NootoContactForm input::placeholder,
body[data-site-theme="portfolio"] .NootoContactForm textarea::placeholder{
  color:var(--folio-muted);
  opacity:.75;
}



/* -----------------------------------------
   FOLIO BUTTONS
----------------------------------------- */

body[data-site-theme="portfolio"] .NootoButton,
body[data-site-theme="portfolio"] .NootoMDButton,
body[data-site-theme="portfolio"] .NootoContinueReading,
body[data-site-theme="portfolio"] .NootoSocialButton,
body[data-site-theme="portfolio"] .NootoContactForm button{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  min-height:42px;
  padding:0 16px;

  background:transparent !important;
  color:var(--site-color) !important;

  border:1px solid var(--folio-line) !important;
  border-radius:10px;

  text-decoration:none !important;

  font-size:.92rem;
  font-weight:700;
  line-height:1;
  white-space:nowrap;

  box-shadow:none !important;

  transition:
    transform .18s ease,
    background .18s ease,
    border-color .18s ease,
    color .18s ease;
}

body[data-site-theme="portfolio"] .NootoButton:hover,
body[data-site-theme="portfolio"] .NootoMDButton:hover,
body[data-site-theme="portfolio"] .NootoContinueReading:hover,
body[data-site-theme="portfolio"] .NootoSocialButton:hover,
body[data-site-theme="portfolio"] .NootoContactForm button:hover{
  background:rgba(255,255,255,.04) !important;
  color:var(--site-color) !important;

  border-color:var(--site-color) !important;

  transform:translateY(-2px);
}




}