html,body{margin:0;padding:0;height:100%;width:100%;overflow-x:hidden;overflow-y:auto;background-color:#0b0f14}:root{font-family:Inter,system-ui,sans-serif;line-height:1.6;color:#f0ebe0;background-color:#0b0f14;--sage-nav: #90b69c;--sage-dark-top: #B6D2BD;--sage-dark-bottom: #8FB89E;--sage-accent: #9FC8A9;--text-light: #FFFFFF;--text-subtle: #E6EFE8}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}nav{position:fixed;top:0;left:0;width:100%;background:#0b0f14e0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(200,169,110,.12);z-index:100}.nav-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.nav-name{font-weight:700;font-size:1.5rem;letter-spacing:-1px;color:#f0ebe0}.nav-links{display:flex;gap:3rem}.nav-links a{text-decoration:none;font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#f0ebe099;transition:color .2s ease}.nav-links a:hover{color:#c8a96e}@media(max-width:800px){.nav-container{padding:.8rem 1.5rem}.nav-name{font-size:1.25rem;letter-spacing:-.5px}.nav-links{gap:1.5rem}}@media(max-width:500px){.nav-container{padding:.7rem 1rem}.nav-name{font-size:1.1rem;letter-spacing:-.4px}.nav-links{gap:1rem}}.hero{position:relative;height:100vh;width:100%;background-color:#0b0f14;display:flex;flex-direction:column;justify-content:center;align-items:center;overflow:hidden}.hero-stars{position:absolute;inset:0;pointer-events:none}.hero-star{position:absolute;border-radius:50%;background:#fff;animation:shimmer 3s ease-in-out infinite}.hero-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;padding:0 2rem;gap:2rem}.hero-eyebrow{display:flex;align-items:center;gap:1rem;animation:fadeUp .9s cubic-bezier(.16,1,.3,1) both}.hero-eyebrow-text{font-size:.7rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:#c8a96e;white-space:nowrap}.hero-eyebrow-rule{display:block;width:48px;height:1px;background:#c8a96e;opacity:.6}.hero-name-block{display:flex;flex-direction:column;align-items:center}.hero-name{font-family:Georgia,Times New Roman,serif;font-size:clamp(72px,14vw,140px);letter-spacing:.06em;line-height:.9;animation:fadeUp .9s cubic-bezier(.16,1,.3,1) both}.hero-name--solid{color:#f0ebe0}.hero-name--outlined{color:transparent;-webkit-text-stroke:1px rgba(240,235,224,.35)}.hero-divider{display:flex;align-items:center;width:100%;max-width:700px;gap:1rem;animation:fadeUp .9s cubic-bezier(.16,1,.3,1) both}.hero-divider-line{flex:1;height:1px;background:#c8a96e4d}.hero-divider-dot{width:5px;height:5px;border-radius:50%;background:#c8a96e;flex-shrink:0;animation:drift 3s ease-in-out infinite}.hero-tagline{font-family:Georgia,Times New Roman,serif;font-size:.8rem;font-style:italic;letter-spacing:.12em;color:#f0ebe08c;white-space:nowrap}.hero-descriptors{display:flex;align-items:center;gap:.75rem;font-size:.65rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#f0ebe073;animation:fadeUp .9s cubic-bezier(.16,1,.3,1) both}.hero-descriptor-sep{color:#c8a96e;opacity:.6}.hero-buttons{display:flex;gap:1.25rem;flex-wrap:wrap;justify-content:center;animation:fadeUp .9s cubic-bezier(.16,1,.3,1) both}.hero-btn{display:inline-block;text-decoration:none;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;border-radius:2px;padding:12px 30px;transition:background .25s ease,color .25s ease,border-color .25s ease,transform .2s ease}.hero-btn--primary{background:#c8a96e;color:#0b0f14;border:1px solid #c8a96e}.hero-btn--primary:hover{background:#d4b882;border-color:#d4b882;transform:translateY(-1px)}.hero-btn--secondary{background:transparent;color:#f0ebe099;border:1px solid rgba(240,235,224,.18)}.hero-btn--secondary:hover{color:#c8a96e;border-color:#c8a96e80;transform:translateY(-1px)}.hero-scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);z-index:1}.hero-scroll-hint-inner{display:flex;flex-direction:column;align-items:center;gap:.5rem;animation:drift 2s ease-in-out infinite}.hero-scroll-label{font-size:.6rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:#f0ebe04d}.hero-scroll-line{display:block;width:1px;height:40px;background:linear-gradient(to bottom,rgba(200,169,110,.4),transparent)}@keyframes fadeUp{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%,to{opacity:.18}50%{opacity:.45}}@keyframes drift{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@media(max-width:600px){.hero-content{gap:1.5rem}.hero-eyebrow-rule{width:24px}.hero-divider{max-width:90%;gap:.6rem}.hero-tagline{font-size:.7rem}.hero-descriptors{flex-direction:column;gap:.4rem}.hero-descriptor-sep{display:none}}#about{background-color:#0d1117;padding:4rem 1.2rem 3.5rem}.about-container{width:100%;max-width:950px;margin:0 auto;text-align:left;color:#f0ebe0bf;padding:0 1.25rem}.about-container h2{color:#c8a96e;font-size:2.5rem;font-weight:800;margin-bottom:20px;text-align:center}.about-container p{line-height:1.8;font-weight:400;font-size:1.3rem;margin-bottom:18px}.about-container em{color:#f0ebe08c;font-style:italic}.dancer-text{position:relative;cursor:pointer;color:#c8a96e;font-weight:400;text-decoration:underline;text-decoration-style:dotted;text-decoration-color:#c8a96e80;text-underline-offset:3px}.dancer-gif{position:fixed;width:140px;pointer-events:none;opacity:0;border-radius:8px;box-shadow:0 8px 24px #00000080;transform:scale(.88);transition:opacity .18s ease,transform .18s ease;z-index:9999}.dancer-text:hover .dancer-gif{opacity:1;transform:scale(1)}@media(max-width:900px){.about-container h2{font-size:2rem}.about-container p{font-size:1.05rem;line-height:1.7}}@media(max-width:600px){#about{padding:2.5rem 1rem}.about-container h2{font-size:1.8rem;margin-bottom:16px}.about-container p{font-size:1rem;line-height:1.65}}@media(max-width:400px){.about-container h2{font-size:1.6rem}.about-container p{font-size:.95rem;line-height:1.6}}.portfolio{background-color:#0b0f14;padding:1.8rem 20px;color:#f0ebe0}.portfolio-container{max-width:1150px;margin:0 auto;margin-bottom:4rem}.portfolio-group{margin-bottom:25px;padding-bottom:3rem;border-bottom:1px solid rgba(200,169,110,.18)}.portfolio-group:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.portfolio-main-title{font-size:2.5rem;font-weight:800;text-align:center;margin-bottom:18px;color:#f0ebe0}.portfolio-title{font-size:1.8rem;font-weight:650;margin-bottom:-10px;color:#c8a96e}.portfolio-subtitle{font-size:1rem;margin-bottom:40px;line-height:1.6;color:#f0ebe08c}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:30px}.project-card{display:flex;flex-direction:column;text-decoration:none;background-color:#131920;border-radius:10px;border:1px solid rgba(200,169,110,.1);box-shadow:0 2px 16px #0006;overflow:hidden;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;cursor:pointer;height:100%}.project-card:hover{transform:translateY(-4px);border-color:#c8a96e59;box-shadow:0 8px 28px #0000008c,0 0 0 1px #c8a96e26}.project-image-wrapper{width:100%;height:180px;overflow:hidden}.project-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-card:hover .project-image{transform:scale(1.03)}.project-content{padding:5px 16px 16px}.project-title{font-size:1.05rem;font-weight:600;color:#f0ebe0;margin-bottom:-10px}.project-description{font-size:.9rem;color:#f0ebe08c;line-height:1.45;margin-bottom:10px}.project-tags{display:flex;flex-wrap:wrap;gap:6px}.project-tag{background-color:#c8a96e1a;color:#c8a96e;border:1px solid rgba(200,169,110,.25);padding:3px 8px;border-radius:4px;font-size:.72rem;font-weight:600;letter-spacing:.08em}.project-modal-overlay{position:fixed;inset:0;z-index:9999;background:#0b0f14e0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;justify-content:center;align-items:center;animation:fadeIn .25s ease}.project-modal{background:#1e2530;border:1px solid rgba(200,169,110,.15);border-radius:20px;box-shadow:0 12px 48px #0009;width:min(80vw,1000px);max-height:90vh;overflow-y:auto;position:relative;animation:scaleIn .25s ease;scrollbar-width:thin;scrollbar-color:rgba(200,169,110,.3) transparent;padding:clamp(20px,3vw,40px);padding-top:0}.project-modal::-webkit-scrollbar{width:8px}.project-modal::-webkit-scrollbar-thumb{background-color:#c8a96e4d;border-radius:10px}.project-modal::-webkit-scrollbar-track{background:transparent}.project-modal-header{position:sticky;top:0;z-index:10;background:#1e2530;padding:1rem 0 .8rem;margin-bottom:1.25rem;border-bottom:1px solid rgba(200,169,110,.15)}.project-modal-header .modal-title{font-size:1.6rem;font-weight:700;color:#f0ebe0;letter-spacing:.3px;text-align:left;margin:0}.project-modal-header .modal-close{position:absolute;top:20px;right:24px;font-size:1.6rem;font-weight:600;background:none;border:none;color:#f0ebe073;cursor:pointer;transition:color .2s ease}.project-modal-header .modal-close:hover{color:#f0ebe0}.modal-content{color:#f0ebe0bf;font-size:1rem;line-height:1.75;max-width:min(90vw,900px);margin:0 auto;text-align:left;animation:fadeSlideIn .4s ease forwards}.modal-content p{margin-bottom:1.25rem}.modal-content strong{color:#f0ebe0;font-weight:600}.modal-content em{color:#f0ebe08c;font-style:italic}.modal-section{margin-bottom:2rem;animation:fadeSlideIn .4s ease forwards}.modal-section+.modal-section{border-top:1px solid rgba(200,169,110,.12);padding-top:1.5rem}.modal-section h3{font-size:1.25rem;font-weight:700;color:#c8a96e;margin-bottom:.75rem;letter-spacing:.2px}.modal-section p{margin-bottom:.75rem;color:#f0ebe0bf;line-height:1.7}@media(max-width:600px){.project-modal{width:95vw;max-height:95vh;border-radius:12px;padding:0 16px 16px}.project-modal-header .modal-title{font-size:1.2rem}.modal-content{font-size:.92rem}.modal-section h3{font-size:1.05rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-image,.modal-image--role,.modal-image--process{display:block;width:100%;max-width:750px;height:auto;object-fit:contain;margin:1.5rem auto;border-radius:10px;box-shadow:0 4px 14px #0000001a;background:none;transition:transform .25s ease,box-shadow .25s ease}.modal-image:hover{transform:scale(1.05);box-shadow:0 6px 20px #0000001f}@media(max-width:900px){.modal-image{max-width:90%}}@media(max-width:600px){.modal-image{max-width:95%;margin:1rem auto}}.contact{background-color:#0b0f14;padding:6rem 1.2rem;border-top:1px solid rgba(200,169,110,.12);min-height:65vh;display:flex;align-items:center;justify-content:center}.contact-container{max-width:700px;width:100%;display:flex;flex-direction:column;align-items:center;gap:2rem;text-align:center}.contact-eyebrow{display:flex;align-items:center;gap:1rem}.contact-eyebrow-text{font-size:.7rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:#c8a96e;white-space:nowrap}.contact-eyebrow-rule{display:block;width:48px;height:1px;background:#c8a96e;opacity:.6}.contact-email{font-family:Georgia,Times New Roman,serif;font-size:clamp(1.2rem,3vw,1.8rem);color:#f0ebe0;text-decoration:none;letter-spacing:.04em;transition:color .2s ease}.contact-email:hover{color:#c8a96e}.contact-links{display:flex;align-items:center;gap:1rem}.contact-link{display:flex;align-items:center;gap:.4rem;text-decoration:none;font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#f0ebe080;transition:color .2s ease}.contact-link:hover{color:#c8a96e}.contact-link-icon{font-size:.9rem}.contact-sep{color:#c8a96e;opacity:.4;font-size:.9rem}@media(max-width:500px){.contact-eyebrow-rule{width:24px}.contact-links{gap:.75rem}}
