.title-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#fff;opacity:1;transition:opacity 1s ease-out;position:fixed;top:0;left:0;right:0;z-index:100}.title-page.fade-out{opacity:0;pointer-events:none}.title-content{text-align:center;font-family:Courier,Courier New,monospace}.title{font-size:3rem;font-weight:400;margin-bottom:2rem;text-transform:uppercase;letter-spacing:.2em;animation:fadeIn .5s ease-in}.written-by{font-size:1.2rem;margin-bottom:2rem;font-style:italic;animation:fadeIn .5s ease-in}.author{font-size:2rem;font-weight:400;animation:fadeIn .5s ease-in}@media (max-width: 768px){.title{font-size:2rem}.written-by{font-size:1rem}.author{font-size:1.5rem}}.scene-heading{min-height:auto;display:flex;align-items:flex-start;padding:2rem 2rem .5rem}.screenplay-content{max-width:900px;margin:0 auto;width:100%;padding-left:10%}.scene-heading-text{font-family:Courier,Courier New,monospace;font-size:1.2rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin:0}@media (max-width: 768px){.screenplay-content{padding-left:5%}.scene-heading-text{font-size:1rem}}.character-intro{min-height:auto;display:flex;align-items:flex-start;padding:0 2rem 4rem;margin-top:0}.character-description{font-family:Courier,Courier New,monospace;font-size:1.1rem;line-height:1.8;margin:0}.character-name{font-weight:700;text-transform:uppercase}.character-title{font-style:italic}@media (max-width: 768px){.character-description{font-size:1rem}}.portfolio-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:2rem;animation:fadeIn .3s ease-in;overflow:hidden}.portfolio-modal-content{position:relative;max-width:90vw;max-height:calc(100vh - 4rem);height:fit-content;background:#fff;border:2px solid #333;box-shadow:0 8px 32px #00000080;animation:modalSlideIn .3s ease-out;overflow:hidden;display:flex;flex-direction:column}.portfolio-modal-close{position:absolute;top:1rem;right:1rem;background:#000000b3;color:#fff;border:2px solid white;width:40px;height:40px;font-size:2rem;line-height:1;cursor:pointer;font-family:Courier,Courier New,monospace;display:flex;align-items:center;justify-content:center;z-index:10001;transition:all .3s ease;padding:0}.portfolio-modal-close:hover{background:#fff;color:#000;border-color:#000}.portfolio-modal-image-container{display:flex;flex-direction:column;align-items:center;flex:1;min-height:0;overflow:hidden}.portfolio-modal-image{max-width:100%;max-height:calc(100vh - 4rem - 80px);width:auto;height:auto;object-fit:contain;display:block;flex-shrink:1}.portfolio-modal-title{font-family:Courier,Courier New,monospace;font-size:1.2rem;text-align:center;padding:1.5rem 2rem;margin:0;background:#fff;border-top:1px solid #333;flex-shrink:0}.portfolio-modal-coming-soon{padding:4rem 2rem;text-align:center;min-width:400px;min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center}.portfolio-modal-coming-soon .portfolio-modal-title{font-size:1.5rem;margin-bottom:1rem;border:none;padding:0}.coming-soon-text{font-family:Courier,Courier New,monospace;font-size:1rem;color:#666;font-style:italic;margin:0}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width: 768px){.portfolio-modal-backdrop{padding:1rem}.portfolio-modal-content{max-width:calc(100vw - 2rem);max-height:calc(100vh - 2rem)}.portfolio-modal-image{max-height:calc(100vh - 2rem - 70px)}.portfolio-modal-close{top:.5rem;right:.5rem;width:35px;height:35px;font-size:1.5rem}.portfolio-modal-title{font-size:1rem;padding:1rem}.portfolio-modal-coming-soon{min-width:auto;min-height:auto;padding:3rem 1.5rem}}.portfolio-section{min-height:80vh;padding:6rem 2rem}.section-title{font-family:Courier,Courier New,monospace;font-size:2rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;margin-bottom:1.5rem}.section-subtitle{font-family:Courier,Courier New,monospace;font-size:1rem;font-style:italic;margin-bottom:2rem;color:#333;animation:fadeIn .5s ease-in}.handwritten-note{font-family:Courier,Courier New,monospace;font-style:italic;position:relative;padding-left:1.5rem}.handwritten-note:before{content:"→";position:absolute;left:0;font-style:normal;opacity:.6}.handwritten-bullet{position:relative;padding-left:1.2rem}.handwritten-bullet:before{content:"•";position:absolute;left:.3rem;opacity:.7}.section-categories{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:3rem;animation:fadeIn .5s ease-in}.category-tag{font-family:Courier,Courier New,monospace;font-size:.95rem;padding:.5rem 1rem;border:1px solid #333;background:transparent;transition:all .3s ease}.category-tag:hover{background:#000;color:#fff}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}.portfolio-item{opacity:0;animation:fadeInUp .6s ease-out forwards;cursor:pointer;transition:transform .3s ease}.portfolio-item:hover{transform:translateY(-5px)}.portfolio-item:hover .item-thumbnail{border-color:#000;box-shadow:0 4px 12px #0003}.portfolio-item:not(.video-item):hover .item-thumbnail:after{content:"Click to expand";position:absolute;bottom:0;left:0;right:0;background:#000c;color:#fff;font-family:Courier,Courier New,monospace;font-size:.75rem;padding:.5rem;text-align:center;pointer-events:none}.portfolio-item.video-item{cursor:default}.portfolio-item.video-item:hover{transform:none}.item-thumbnail{width:100%;aspect-ratio:16 / 9;background:#f0f0f0;border:2px solid #333;margin-bottom:1rem;overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.item-thumbnail:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border:1px solid rgba(0,0,0,.1);pointer-events:none}.item-thumbnail img{width:100%;height:100%;object-fit:cover}.portfolio-video{width:100%;height:100%;object-fit:cover;outline:none}.placeholder-thumbnail{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:Courier,Courier New,monospace;font-size:.9rem;color:#999;text-align:center;padding:1rem;background:linear-gradient(135deg,#f5f5f5,#e8e8e8)}.writing-section .item-thumbnail{aspect-ratio:8.5 / 11;background:#fff;border:1px solid #333;box-shadow:0 2px 4px #0000001a}.writing-section .placeholder-thumbnail{background:#fff;color:#333;font-size:.85rem;line-height:1.6;padding:1.5rem;text-align:left}.item-title{font-family:Courier,Courier New,monospace;font-size:.95rem;text-align:center;margin:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.portfolio-section{padding:4rem 1.5rem}.section-title{font-size:1.5rem}.portfolio-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}}.fade-to-black-section{min-height:150vh;display:flex;align-items:center;justify-content:center;position:relative;padding:4rem 2rem;margin-bottom:0;background:#fff}.fade-to-black-text{font-family:Courier,Courier New,monospace;font-size:1.2rem;text-align:center;margin-bottom:2rem;font-weight:700}.fade-to-black-text strong{font-weight:700;text-transform:uppercase;letter-spacing:.1em}.scroll-indicator{text-align:center;padding:2rem 0;pointer-events:none}.scroll-arrow{font-size:3rem;display:inline-block;animation:bounce 2s infinite;color:#333;pointer-events:none;-webkit-user-select:none;user-select:none}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.black-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000;opacity:0;pointer-events:none;transition:opacity .1s linear;z-index:999;will-change:opacity;touch-action:none;-webkit-overflow-scrolling:touch}@media (max-width: 768px){.scene-direction{font-size:1rem}}.contact-section{min-height:100vh;background:#000;color:#fff;display:flex;align-items:center;justify-content:center;padding:4rem 2rem;position:relative;z-index:1000;margin-top:0}.contact-content{text-align:center;max-width:600px}.contact-title{font-family:Courier,Courier New,monospace;font-size:2.5rem;font-weight:700;letter-spacing:.2em;margin-bottom:3rem;color:#fff;position:relative}.contact-title:before{content:"";position:absolute;left:-2rem;top:50%;transform:translateY(-50%);width:1.5rem;height:2px;background:#fff;opacity:.6}.contact-details{display:flex;flex-direction:column;gap:1.5rem;animation:fadeIn 1s ease-in}.contact-button{font-family:Courier,Courier New,monospace;font-size:1.2rem;color:#fff;text-decoration:none;padding:1rem 2rem;border:2px solid white;transition:all .3s ease;position:relative;display:inline-block;background:transparent;cursor:pointer;font-weight:700;margin-bottom:2rem}.contact-button:hover{background:#fff;color:#000}.contact-info{display:flex;flex-direction:column;gap:1rem}.contact-email,.contact-phone{font-family:Courier,Courier New,monospace;font-size:1.1rem;color:#fff;text-decoration:none;transition:opacity .3s ease}.contact-email:hover,.contact-phone:hover{opacity:.7}@media (max-width: 768px){.contact-title{font-size:1.8rem}.contact-link{font-size:1rem}}.screenplay-page{position:relative;background:#fff;min-height:100vh;font-family:Courier,Courier New,monospace;font-size:12pt;overflow-y:auto}.screenplay-page>*{opacity:1;animation:fadeIn .8s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.screenplay-content{max-width:900px;margin:0 auto;width:100%;padding-left:10%;padding-right:10%;position:relative;z-index:2}html{scroll-behavior:smooth}body{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}body::-webkit-scrollbar{width:8px}body::-webkit-scrollbar-track{background:transparent}body::-webkit-scrollbar-thumb{background-color:#0003;border-radius:4px}@media (max-width: 768px){.screenplay-page{font-size:11pt}.screenplay-content{padding-left:5%;padding-right:5%}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Courier,Courier New,monospace;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;color:#000;overflow-x:hidden;overflow-y:auto}#root{min-height:100vh}.screenplay-page{position:relative;background:#fff;min-height:100vh}.screenplay-page:before,.screenplay-page:after{content:"";position:fixed;top:0;bottom:0;width:15%;pointer-events:none;z-index:1}.screenplay-page:before{left:0;background:linear-gradient(to right,rgba(0,0,0,.08),transparent)}.screenplay-page:after{right:0;background:linear-gradient(to left,rgba(0,0,0,.08),transparent)}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}.cursor{display:inline-block;width:2px;height:1.2em;background-color:#000;margin-left:2px;animation:blink 1s infinite;vertical-align:text-bottom}.cursor.typing{animation:none;opacity:1}html{scroll-behavior:smooth;background:#fff}::selection{background:#0003;color:#000}
