@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@100..900&family=Playfair+Display:ital,wght@0,400..900;1,400..900&display=swap');

:root{
  --bg:#0a0a0a;--bg2:#111;--charcoal:#1a1a1a;
  --w:#fff;--ws:rgba(255,255,255,.85);--wm:rgba(255,255,255,.5);
  --orange:#e8732a;--blue:#1a3a5c;--green:#1a3d2e;
  --glow:rgba(232,115,42,.15);--glass:rgba(255,255,255,.04);--gborder:rgba(255,255,255,.08);
  --heading:'Outfit',sans-serif;--editorial:'Playfair Display',serif;--body:'Outfit',sans-serif;
  --ease:cubic-bezier(.25,.46,.45,.94);--easeOut:cubic-bezier(.22,1,.36,1);
}

/* === BASE === */
.lop{margin:0;padding:0;background:var(--bg);color:var(--w);font-family:var(--body);overflow-x:hidden;-webkit-font-smoothing:antialiased}
.lop *,.lop *::before,.lop *::after{box-sizing:border-box;margin:0;padding:0}
.lop img,.lop video{display:block;max-width:100%}
.lop-wrap{position:relative}

/* === LOADER === */
.lop-loader{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column;transition:opacity .8s var(--ease),visibility .8s}
.lop-loader.done{opacity:0;visibility:hidden;pointer-events:none}
.lop-loader h2{font-family:var(--editorial);font-size:clamp(1.4rem,4vw,2.8rem);font-weight:300;font-style:italic;opacity:0;animation:ldFade 2s var(--ease) forwards;letter-spacing:.05em}
.lop-loader-bar{width:120px;height:2px;background:var(--charcoal);margin-top:28px;border-radius:2px;overflow:hidden}
.lop-loader-bar::after{content:'';display:block;height:100%;background:var(--orange);animation:ldBar 2.2s var(--ease) forwards}
@keyframes ldFade{0%{opacity:0;transform:translateY(20px)}30%{opacity:1;transform:translateY(0)}100%{opacity:.6}}
@keyframes ldBar{from{width:0}to{width:100%}}

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

/* === MOUSE GLOW === */
.lop-glow{position:fixed;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,var(--glow) 0%,transparent 70%);pointer-events:none;z-index:1;transform:translate(-50%,-50%);opacity:.5}

/* === NAV === */
.lop-nav{position:fixed;top:0;left:0;right:0;z-index:9990;padding:24px 40px;display:flex;justify-content:space-between;align-items:center;transition:background .4s,backdrop-filter .4s}
.lop-nav.scrolled{background:rgba(10,10,10,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.lop-nav a{display:flex;align-items:center;gap:10px;color:var(--ws);text-decoration:none;font-size:.85rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;transition:color .3s,gap .3s}
.lop-nav a:hover{color:var(--orange);gap:14px}
.lop-nav a svg{transition:transform .3s}
.lop-nav a:hover svg{transform:translateX(-4px)}
.lop-nav-title{font-family:var(--editorial);font-size:.9rem;font-style:italic;color:var(--wm);letter-spacing:.05em}

/* === HERO === */
.lop-hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.lop-hero-bg{position:absolute;inset:0}
.lop-hero-bg img{width:100%;height:100%;object-fit:cover;will-change:transform}
.lop-hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.4) 0%,rgba(10,10,10,.15) 40%,rgba(10,10,10,.6) 70%,rgba(10,10,10,.95) 100%)}
.lop-hero-content{position:relative;z-index:2;text-align:center;max-width:900px;padding:0 24px}
.lop-hero h1{font-family:var(--heading);font-size:clamp(3rem,10vw,7.5rem);font-weight:800;line-height:.95;letter-spacing:-.03em;margin-bottom:24px;opacity:0;transform:translateY(60px);animation:hReveal 1.2s var(--easeOut) 2.5s forwards;background:linear-gradient(135deg,#fff 0%,rgba(255,255,255,.7) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.lop-hero p{font-family:var(--editorial);font-size:clamp(1rem,2.5vw,1.35rem);font-weight:300;font-style:italic;color:var(--ws);line-height:1.6;max-width:600px;margin:0 auto;opacity:0;transform:translateY(40px);animation:hReveal 1.2s var(--easeOut) 2.9s forwards}
@keyframes hReveal{to{opacity:1;transform:translateY(0)}}

.lop-scroll-cta{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:hReveal 1s var(--easeOut) 3.4s forwards;cursor:pointer}
.lop-scroll-cta span{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--wm)}
.lop-scroll-line{width:1px;height:50px;background:var(--wm);position:relative;overflow:hidden}
.lop-scroll-line::after{content:'';position:absolute;top:-50px;left:0;width:100%;height:50px;background:var(--orange);animation:sLine 2s var(--ease) infinite}
@keyframes sLine{0%{top:-50px}100%{top:50px}}

/* === REVEAL SYSTEM === */
.rv{opacity:0;transform:translateY(60px);transition:opacity .9s var(--easeOut),transform .9s var(--easeOut)}
.rv.on{opacity:1;transform:translateY(0)}
.rv-l{opacity:0;transform:translateX(-80px);transition:opacity .9s var(--easeOut),transform .9s var(--easeOut)}
.rv-l.on{opacity:1;transform:translateX(0)}
.rv-r{opacity:0;transform:translateX(80px);transition:opacity .9s var(--easeOut),transform .9s var(--easeOut)}
.rv-r.on{opacity:1;transform:translateX(0)}

/* === SECTION CONTAINER === */
.lop-c{max-width:1300px;margin:0 auto;padding:0 40px}
.lop-label{display:inline-flex;align-items:center;gap:12px;font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);margin-bottom:40px}
.lop-label::before{content:'';width:40px;height:1px;background:var(--orange)}

/* === JOURNEY === */
.lop-journey{padding:140px 0}
.lop-journey-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.lop-journey-img{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/5}
.lop-journey-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.lop-journey-img:hover img{transform:scale(1.05)}
.lop-journey-img::after{content:'';position:absolute;inset:0;border:1px solid var(--gborder);border-radius:16px;pointer-events:none}
.lop-journey-txt h2{font-family:var(--heading);font-size:clamp(2rem,4vw,3.2rem);font-weight:700;line-height:1.15;margin-bottom:32px;letter-spacing:-.02em}
.lop-journey-txt h2 em{font-family:var(--editorial);font-weight:400;color:var(--orange)}
.lop-journey-txt p{font-size:1.05rem;line-height:1.85;color:var(--ws);margin-bottom:20px;font-weight:300}

/* === CINEMATIC PARALLAX === */
.lop-cine{position:relative;height:80vh;min-height:500px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.lop-cine-bg{position:absolute;inset:-60px;z-index:0}
.lop-cine-bg img{width:100%;height:100%;object-fit:cover;will-change:transform}
.lop-cine-bg::after{content:'';position:absolute;inset:0;background:rgba(10,10,10,.55);z-index:1}
.lop-cine-txt{position:relative;z-index:2;text-align:center;max-width:800px;padding:0 24px}
.lop-cine-txt h3{font-family:var(--heading);font-size:clamp(2rem,5vw,3.5rem);font-weight:700;line-height:1.2;letter-spacing:-.02em}
.lop-cine-txt p{font-family:var(--editorial);font-size:1.15rem;font-style:italic;color:var(--ws);margin-top:20px;font-weight:300}

/* === GALLERY === */
.lop-gallery{padding:120px 0}
.lop-gallery-head{text-align:center;margin-bottom:70px}
.lop-gallery-head h2{font-family:var(--heading);font-size:clamp(2rem,5vw,3.5rem);font-weight:800;letter-spacing:-.02em;margin-bottom:16px}
.lop-gallery-head p{font-family:var(--editorial);font-size:1.1rem;font-style:italic;color:var(--wm);font-weight:300}
.lop-masonry{columns:3;column-gap:20px}
.lop-m-item{break-inside:avoid;margin-bottom:20px;position:relative;border-radius:12px;overflow:hidden;cursor:pointer}
.lop-m-item img,.lop-m-item video{width:100%;display:block;border-radius:12px;transition:transform .7s var(--ease),filter .7s;object-fit:cover}
.lop-m-item:hover img,.lop-m-item:hover video{transform:scale(1.08);filter:brightness(1.1)}
.lop-m-ov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,10,10,.8) 0%,transparent 50%);opacity:0;transition:opacity .5s;display:flex;align-items:flex-end;padding:24px;border-radius:12px}
.lop-m-item:hover .lop-m-ov{opacity:1}
.lop-m-cap{font-family:var(--editorial);font-size:1.05rem;font-style:italic;color:var(--ws);transform:translateY(10px);transition:transform .5s var(--ease)}
.lop-m-item:hover .lop-m-cap{transform:translateY(0)}

/* === TIMELINE === */
.lop-tl{padding:140px 0;background:var(--bg2)}
.lop-tl-head{text-align:center;margin-bottom:80px}
.lop-tl-head h2{font-family:var(--heading);font-size:clamp(2rem,5vw,3.5rem);font-weight:800;letter-spacing:-.02em;margin-bottom:16px}
.lop-tl-track{position:relative;max-width:900px;margin:0 auto}
.lop-tl-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(180deg,transparent,var(--gborder) 10%,var(--gborder) 90%,transparent);transform:translateX(-50%)}
.lop-tl-item{display:flex;align-items:flex-start;margin-bottom:80px;position:relative}
.lop-tl-item:nth-child(even){flex-direction:row-reverse}
.lop-tl-card{width:calc(50% - 40px);background:var(--glass);border:1px solid var(--gborder);border-radius:16px;padding:32px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:transform .4s var(--ease),border-color .4s}
.lop-tl-card:hover{transform:translateY(-4px);border-color:rgba(232,115,42,.3)}
.lop-tl-dot{position:absolute;left:50%;top:32px;width:16px;height:16px;border-radius:50%;background:var(--orange);transform:translateX(-50%);z-index:2;box-shadow:0 0 20px rgba(232,115,42,.4)}
.lop-tl-yr{font-size:.75rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--orange);margin-bottom:10px}
.lop-tl-place{font-family:var(--heading);font-size:1.3rem;font-weight:700;margin-bottom:10px}
.lop-tl-desc{font-size:.95rem;line-height:1.7;color:var(--wm);font-weight:300}

/* === EXPOSURE / QUOTES === */
.lop-expo{padding:160px 0;overflow:hidden}
.lop-quote{text-align:center;max-width:1000px;margin:0 auto 100px;padding:0 24px}
.lop-quote blockquote{font-family:var(--editorial);font-size:clamp(1.8rem,4vw,3rem);font-weight:400;font-style:italic;line-height:1.5;position:relative}
.lop-quote blockquote::before{content:'\201C';font-size:6rem;color:var(--orange);position:absolute;top:-40px;left:-20px;opacity:.3;font-family:var(--editorial)}
.lop-quote cite{display:block;margin-top:24px;font-size:.85rem;color:var(--wm);letter-spacing:.15em;text-transform:uppercase;font-weight:500;font-style:normal}
.lop-big{font-family:var(--heading);font-size:clamp(4rem,12vw,10rem);font-weight:900;line-height:.9;text-align:center;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.08);letter-spacing:-.04em;user-select:none;padding:40px 0}

/* === ENDING === */
.lop-end{position:relative;height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.lop-end-bg{position:absolute;inset:0}
.lop-end-bg img{width:100%;height:100%;object-fit:cover}
.lop-end-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.5) 0%,rgba(10,10,10,.75) 50%,rgba(10,10,10,.95) 100%)}
.lop-end-content{position:relative;z-index:2;text-align:center;max-width:800px;padding:0 24px}
.lop-end-line{width:60px;height:2px;background:var(--orange);margin:0 auto 30px}
.lop-end-content blockquote{font-family:var(--editorial);font-size:clamp(1.5rem,3.5vw,2.5rem);font-weight:400;font-style:italic;line-height:1.6;margin-bottom:40px}
.lop-end-btn{display:inline-flex;align-items:center;gap:10px;color:var(--wm);text-decoration:none;font-size:.8rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;padding:14px 32px;border:1px solid var(--gborder);border-radius:50px;transition:color .3s,gap .3s,border-color .3s}
.lop-end-btn:hover{color:var(--orange);border-color:rgba(232,115,42,.4);gap:14px}

/* === RESPONSIVE === */
@media(max-width:1024px){.lop-masonry{columns:2}.lop-journey-grid{gap:50px}}
@media(max-width:768px){
  .lop-nav{padding:16px 20px}.lop-nav-title{display:none}
  .lop-c{padding:0 20px}
  .lop-journey{padding:80px 0}.lop-journey-grid{grid-template-columns:1fr;gap:40px}.lop-journey-img{aspect-ratio:16/10}
  .lop-masonry{columns:1}.lop-gallery{padding:80px 0}
  .lop-tl{padding:80px 0}.lop-tl-line{left:20px}
  .lop-tl-item,.lop-tl-item:nth-child(even){flex-direction:row;padding-left:50px}
  .lop-tl-card{width:100%;padding:24px}.lop-tl-dot{left:20px}
  .lop-expo{padding:80px 0}.lop-cine{height:60vh;min-height:400px}
  .lop-big{font-size:clamp(2.5rem,10vw,5rem)}
  .lop-hero{min-height:100svh}
}
@media(max-width:480px){.lop-hero h1{font-size:2.5rem}.lop-tl-card{padding:20px}.lop-quote blockquote{font-size:1.4rem}}
