/*
Theme Name: Jason Theme
Theme URI: http://example.com/jason-theme
Author: Antigravity
Author URI: http://example.com
Description: A premium cinematic portfolio theme tailor-made for Jason.
Version: 1.0.0
Text Domain: jason-theme
*/

*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --sage:#8a9e8c;
  --sage-light:#b8c9b9;
  --sage-dark:#5a7059;
  --cream:#f0ede6;
  --cream2:#e8e3da;
  --warm:#d4c9b0;
  --charcoal:#1c1c1c;
  --near-black:#111111;
  --mid:#6b6b6b;
  --light-mid:#9a9a9a;
  --white-warm:#faf8f4;
  --accent-green:#6b8f6d;
}
html{scroll-behavior:smooth;}
body{
  font-family:'Syne',sans-serif;
  background:var(--cream);
  color:var(--charcoal);
  overflow-x:hidden;
  cursor:none;
}
.cursor{
  width:8px;height:8px;
  background:var(--charcoal);
  border-radius:50%;
  position:fixed;
  pointer-events:none;
  z-index:9999;
  transition:transform 0.15s ease, opacity 0.3s;
  transform:translate(-50%,-50%);
}
.cursor-ring{
  width:32px;height:32px;
  border:1px solid rgba(28,28,28,0.4);
  border-radius:50%;
  position:fixed;
  pointer-events:none;
  z-index:9998;
  transition:transform 0.4s cubic-bezier(0.23,1,0.32,1), width 0.3s, height 0.3s, opacity 0.3s;
  transform:translate(-50%,-50%);
}
.cursor-ring.expand{width:56px;height:56px;opacity:0.5;}

nav{
  position:fixed;top:0;left:0;right:0;
  z-index:100;
  display:flex;justify-content:space-between;align-items:center;
  padding:2rem 3.5rem;
  mix-blend-mode:normal;
}
.nav-bg{
  position:fixed;top:0;left:0;right:0;height:80px;
  background:linear-gradient(180deg,rgba(240,237,230,0.95) 0%,rgba(240,237,230,0) 100%);
  z-index:99;pointer-events:none;
}
.nav-logo{
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem;font-weight:300;
  letter-spacing:3px;color:var(--charcoal);
  text-decoration:none;
  font-style:italic;
}
.nav-links{
  display:flex;gap:3rem;list-style:none;
  position:relative;z-index:101;
}
.nav-links a{
  font-size:0.7rem;letter-spacing:3px;
  text-transform:uppercase;
  color:var(--mid);text-decoration:none;
  transition:color 0.3s;
}
.nav-links a:hover{color:var(--charcoal);}

/* HERO */
.hero{
  height:100vh;
  display:grid;
  grid-template-columns:1fr 1fr;
  position:relative;overflow:hidden;
}
.hero-left{
  background:var(--cream);
  display:flex;flex-direction:column;
  justify-content:flex-end;
  padding:0 3.5rem 5rem;
  position:relative;z-index:2;
}
.hero-eyebrow{
  font-size:0.65rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--sage-dark);
  margin-bottom:1.5rem;
}
.hero-name{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(4rem,7vw,8rem);
  font-weight:300;line-height:0.9;
  letter-spacing:-1px;color:var(--charcoal);
  margin-bottom:1.5rem;
}
.hero-name em{font-style:italic;color:var(--sage-dark);}
.hero-role{
  font-size:0.68rem;letter-spacing:3px;
  text-transform:uppercase;color:var(--mid);
  margin-bottom:3rem;line-height:2;
}
.hero-scroll{
  display:flex;align-items:center;gap:1rem;
  font-size:0.6rem;letter-spacing:3px;
  text-transform:uppercase;color:var(--light-mid);
}
.hero-scroll-line{
  width:40px;height:1px;
  background:var(--light-mid);
  display:inline-block;
}
.hero-right{
  position:relative;overflow:hidden;
}
.hero-img{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  filter:grayscale(15%) contrast(1.05);
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(240,237,230,0.3) 0%,transparent 40%);
}
.hero-tag{
  position:absolute;bottom:3rem;right:2.5rem;
  font-size:0.6rem;letter-spacing:3px;
  text-transform:uppercase;color:rgba(255,255,255,0.5);
  writing-mode:vertical-rl;
  text-orientation:mixed;
}
.hero-number{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-family:'Cormorant Garamond',serif;
  font-size:20rem;font-weight:300;
  color:rgba(138,158,140,0.06);
  pointer-events:none;user-select:none;
  white-space:nowrap;
}

/* ABOUT */
.about{
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr 1.1fr;
  background:var(--near-black);
  position:relative;overflow:hidden;
}
.about-visual{
  position:relative;overflow:hidden;
}
.about-cinematic-stack{
  width:100%;height:100%;
  object-fit:cover;
  filter:sepia(8%) contrast(1.1) brightness(0.85);
}
.about-vignette{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 70% 50%, transparent 40%, rgba(17,17,17,0.6) 100%);
}
.about-right{
  padding:7rem 4rem 5rem 3.5rem;
  display:flex;flex-direction:column;justify-content:center;
  background:var(--near-black);
}
.about-label{
  font-size:0.6rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--sage);
  margin-bottom:2.5rem;
  display:flex;align-items:center;gap:1rem;
}
.about-label::before{
  content:'';display:inline-block;
  width:30px;height:1px;background:var(--sage);
}
.about-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,3.5vw,3.2rem);
  font-weight:300;color:#f0ede6;
  line-height:1.2;margin-bottom:2.5rem;
  letter-spacing:-0.5px;
}
.about-title em{font-style:italic;color:var(--sage-light);}
.about-body{
  font-family:'Cormorant Garamond',serif;
  font-size:1.08rem;line-height:1.9;
  color:rgba(240,237,230,0.65);
  font-weight:300;
}
.about-body p{margin-bottom:1.2rem;}
.about-body strong{
  color:rgba(240,237,230,0.9);
  font-weight:400;
}
.about-stats{
  display:flex;gap:3rem;margin-top:3rem;
  padding-top:2rem;
  border-top:1px solid rgba(240,237,230,0.1);
}
.stat-num{
  font-family:'Cormorant Garamond',serif;
  font-size:2.5rem;font-weight:300;
  color:var(--sage-light);display:block;
  line-height:1;margin-bottom:0.4rem;
}
.stat-label{
  font-size:0.62rem;letter-spacing:2.5px;
  text-transform:uppercase;
  color:rgba(240,237,230,0.35);
}

/* WORK */
.work{
  padding:8rem 3.5rem;
  background:var(--cream);
}
.section-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:5rem;
}
.section-label{
  font-size:0.6rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--sage-dark);
  margin-bottom:1rem;
}
.section-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.5rem,4vw,4rem);
  font-weight:300;color:var(--charcoal);
  line-height:1;letter-spacing:-1px;
}
.section-count{
  font-family:'Cormorant Garamond',serif;
  font-size:5rem;font-weight:300;
  color:rgba(138,158,140,0.18);
  line-height:1;
}
.work-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:1.5px;
  background:var(--warm);
}
.work-item{
  position:relative;overflow:hidden;
  background:var(--cream2);
  aspect-ratio:4/5;
  cursor:none;
}
.work-item:first-child{grid-column:span 2;aspect-ratio:auto;min-height:420px;}
.work-thumb{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.wbg1{background:linear-gradient(135deg,#2a2f2a 0%,#1a2018 100%);}
.wbg2{background:linear-gradient(135deg,#1e2a1e 0%,#2a3020 100%);}
.wbg3{background:linear-gradient(135deg,#282420 0%,#1e1a16 100%);}
.wbg4{background:linear-gradient(135deg,#1a2424 0%,#0e1818 100%);}
.work-placeholder{
  font-family:'Cormorant Garamond',serif;
  font-size:0.7rem;letter-spacing:3px;
  text-transform:uppercase;
  color:rgba(255,255,255,0.15);
  text-align:center;
}
.work-hover{
  position:absolute;inset:0;
  background:rgba(17,17,17,0.75);
  display:flex;flex-direction:column;
  justify-content:flex-end;
  padding:2rem;
  opacity:0;
  transition:opacity 0.4s ease;
}
.work-item:hover .work-hover{opacity:1;}
.work-type{
  font-size:0.6rem;letter-spacing:3px;
  text-transform:uppercase;color:var(--sage-light);
  margin-bottom:0.5rem;
}
.work-title-hover{
  font-family:'Cormorant Garamond',serif;
  font-size:1.4rem;font-weight:300;
  color:#f0ede6;line-height:1.2;
}
.work-body-info{
  padding:1.5rem 1.75rem;
  background:var(--cream2);
  border-top:1px solid var(--warm);
}
.work-title-text{
  font-size:0.82rem;font-weight:500;
  letter-spacing:0.5px;color:var(--charcoal);
  margin-bottom:0.35rem;
}
.work-meta-text{
  font-size:0.7rem;color:var(--mid);
  letter-spacing:1px;
}

footer{
  background:var(--near-black);
  border-top:1px solid rgba(240,237,230,0.07);
  padding:2rem 3.5rem;
  display:flex;justify-content:space-between;align-items:center;
}
.footer-logo{
  font-family:'Cormorant Garamond',serif;
  font-size:1rem;font-weight:300;
  font-style:italic;letter-spacing:2px;
  color:rgba(240,237,230,0.4);
}
.footer-copy{
  font-size:0.6rem;letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(240,237,230,0.2);
}
.footer-socials{display:flex;gap:2rem;}
.footer-socials a{
  font-size:0.6rem;letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(240,237,230,0.25);
  text-decoration:none;transition:color 0.3s;
}
.footer-socials a:hover{color:var(--sage);}

.grain-overlay{
  position:fixed;inset:0;
  pointer-events:none;z-index:999;
  opacity:0.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:256px;
}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(30px);}
  to{opacity:1;transform:translateY(0);}
}
.hero-left > *{
  opacity:0;animation:fadeUp 0.9s cubic-bezier(0.23,1,0.32,1) forwards;
}
.hero-eyebrow{animation-delay:0.3s;}
.hero-name{animation-delay:0.5s;}
.hero-role{animation-delay:0.7s;}
.hero-scroll{animation-delay:0.9s;}

@media(max-width:900px){
  .hero,.about{grid-template-columns:1fr;}
  .hero-right{height:60vw;}
  .about-visual{height:60vw;}
  .contact-inner,.skills-grid{grid-template-columns:1fr;}
  nav{padding:1.5rem 1.5rem;}
  .work,.skills,.contact{padding:5rem 1.5rem;}
  .work-grid{grid-template-columns:1fr 1fr;}
  .work-item:first-child{grid-column:span 2;}
}
/* CONTACT */
.contact{
  background:var(--near-black);
  padding:8rem 3.5rem 5rem;
  position:relative;overflow:hidden;
}
.contact-bg-text{
  position:absolute;bottom:-2rem;right:-1rem;
  font-family:'Cormorant Garamond',serif;
  font-size:18vw;font-weight:300;
  color:rgba(138,158,140,0.04);
  line-height:1;user-select:none;
  pointer-events:none;white-space:nowrap;
}
.contact-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6rem;
  position:relative;z-index:2;
}
.contact-left{}
.contact-big{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,5vw,5.5rem);
  font-weight:300;
  color:#f0ede6;
  line-height:1;
  letter-spacing:-1px;
  margin-bottom:2rem;
}
.contact-big em{color:var(--sage-light);font-style:italic;}
.contact-sub{
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;color:rgba(240,237,230,0.45);
  line-height:1.8;font-weight:300;
  max-width:340px;margin-bottom:3rem;
}
.contact-info{display:flex;flex-direction:column;gap:1.5rem;}
.ci-label{
  font-size:0.58rem;letter-spacing:3px;
  text-transform:uppercase;color:var(--sage);
  margin-bottom:0.25rem;
}
.ci-value{
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;color:rgba(240,237,230,0.7);
  font-weight:300;
}
.contact-form-side{
  display:flex;flex-direction:column;gap:0;
  padding-top:0.5rem;
}
.cf-field{
  border-bottom:1px solid rgba(240,237,230,0.12);
  padding:1.5rem 0;
}
.cf-label-form{
  font-size:0.58rem;letter-spacing:3px;
  text-transform:uppercase;color:var(--sage);
  display:block;margin-bottom:0.75rem;
}
.cf-input-form,.cf-textarea-form{
  width:100%;background:transparent;
  border:none;outline:none;
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;font-weight:300;
  color:rgba(240,237,230,0.8);
  caret-color:var(--sage);
}
.cf-input-form::placeholder,.cf-textarea-form::placeholder{
  color:rgba(240,237,230,0.2);
  font-style:italic;
}
.cf-textarea-form{resize:none;min-height:100px;line-height:1.6;}
.cf-submit{
  margin-top:2.5rem;
  display:flex;align-items:center;gap:1.5rem;
  cursor:none;
  background:none;border:none;
  padding:0;
}
.cf-submit-text{
  font-size:0.7rem;letter-spacing:3px;
  text-transform:uppercase;color:#f0ede6;
  transition:color 0.3s;
}
.cf-submit-circle{
  width:48px;height:48px;
  border:1px solid rgba(240,237,230,0.25);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.3s, border-color 0.3s;
  flex-shrink:0;
}
.cf-submit:hover .cf-submit-circle{
  background:var(--sage-dark);
  border-color:var(--sage-dark);
}
.cf-submit-arrow{
  color:rgba(240,237,230,0.6);
  font-size:1rem;
  transition:color 0.3s;
}
.cf-submit:hover .cf-submit-arrow{color:white;}
