/* ShotArch — Editorial Magazine Design */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,500&display=swap');

:root{
  --black:#0b0b0b;--dark:#111;--mid:#1a1a1a;
  --white:#fff;--off:#e8e8e8;--gray:#888;--dim:#444;
  --accent:#ff5e3a;
  --r:12px;--ease:cubic-bezier(.22,1,.36,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
body{font-family:'Inter',sans-serif;background:var(--black);color:var(--white);line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}ul{list-style:none}
::selection{background:var(--accent);color:#fff}

/* ---- PRELOADER ---- */
#preloader{position:fixed;inset:0;z-index:10000;background:var(--black);display:flex;align-items:center;justify-content:center;flex-direction:column;transition:clip-path 1s var(--ease);clip-path:inset(0)}
#preloader.bye{clip-path:inset(0 0 100% 0)}
#preloader .p-logo{font-family:'Playfair Display',serif;font-size:3rem;font-weight:800;letter-spacing:.05em}
#preloader .p-logo span{color:var(--accent)}
#preloader .p-bar{width:180px;height:2px;background:#222;margin-top:1.5rem;border-radius:2px;overflow:hidden}
#preloader .p-fill{height:100%;width:0;background:var(--accent);border-radius:2px}

/* ---- CURSOR ---- */
.cur{position:fixed;width:16px;height:16px;border:1.5px solid rgba(255,255,255,.5);border-radius:50%;pointer-events:none;z-index:9999;transition:width .25s var(--ease),height .25s var(--ease),border-color .2s,background .2s;mix-blend-mode:difference}
.cur-d{position:fixed;width:5px;height:5px;background:#fff;border-radius:50%;pointer-events:none;z-index:10000}
.cur.big{width:60px;height:60px;border-color:var(--accent);background:rgba(255,94,58,.08)}

/* ---- NAV ---- */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 4%;display:flex;justify-content:space-between;align-items:center;transition:all .5s var(--ease)}
.nav.solid{background:rgba(11,11,11,.9);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,.05)}
.n-logo{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:800;letter-spacing:.02em;display:flex;align-items:center;gap:8px}
.n-logo img{height:28px;filter:brightness(0) invert(1)}
.n-logo b{color:var(--accent)}
.n-links{display:flex;align-items:center;gap:2.2rem}
.n-links a{font-size:.8rem;font-weight:500;color:rgba(255,255,255,.85);letter-spacing:.1em;text-transform:uppercase;transition:color .3s}
.n-links a:hover,.n-links a.on{color:#fff}
.n-dd{position:relative}
.n-dd-p{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%);min-width:200px;background:rgba(17,17,17,.97);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.06);border-radius:var(--r);padding:8px;opacity:0;visibility:hidden;transition:all .25s var(--ease)}
.n-dd:hover .n-dd-p{opacity:1;visibility:visible}
.n-dd-p a{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:.82rem;text-transform:none;letter-spacing:0;color:#fff}
.n-dd-p a:hover{background:rgba(255,94,58,.08);color:var(--accent)}
.n-est{padding:9px 22px;border:1.5px solid var(--accent);border-radius:50px;color:var(--accent);font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:all .3s var(--ease)}
.n-est:hover{background:var(--accent);color:#fff}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:1001}
.burger s{display:block;width:26px;height:1.5px;background:#fff;text-decoration:none;transition:all .3s var(--ease)}
.burger.on s:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.burger.on s:nth-child(2){opacity:0}
.burger.on s:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ---- HERO ---- */
.hero{height:100vh;position:relative;display:flex;align-items:flex-end;overflow:hidden}
.hero-media{position:absolute;inset:0}
.hero-media img{width:100%;height:100%;object-fit:cover;filter:brightness(.35) saturate(.7)}
.hero-media::after{content:'';position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to top,var(--black),transparent)}
.hero-inner{position:relative;z-index:2;width:100%;padding:0 4% 6%}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(3rem,8vw,8rem);font-weight:900;line-height:.95;letter-spacing:-.04em;margin-bottom:1.5rem}
.hero h1 i{font-style:italic;color:var(--accent);font-weight:500}
.hero-desc{font-size:clamp(.95rem,1.5vw,1.15rem);color:var(--off);max-width:550px;line-height:1.9;margin-bottom:2.5rem;opacity:.85}
.hero-row{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.h-btn{display:inline-flex;align-items:center;gap:10px;padding:16px 40px;border-radius:50px;font-weight:600;font-size:.9rem;transition:all .4s var(--ease)}
.h-btn-fill{background:var(--accent);color:#fff}
.h-btn-fill:hover{background:#ff7a5c;transform:translateY(-3px);box-shadow:0 12px 32px rgba(255,94,58,.3)}
.h-btn-line{border:1.5px solid rgba(255,255,255,.2);color:#fff}
.h-btn-line:hover{border-color:#fff;transform:translateY(-2px)}
.hero-nums{position:absolute;right:4%;bottom:6%;z-index:3;display:flex;gap:3.5rem}
.hero-nums div{text-align:right}
.hero-nums .v{font-family:'Playfair Display',serif;font-size:3rem;font-weight:800;color:var(--accent);line-height:1}
.hero-nums .k{font-size:.7rem;color:var(--gray);text-transform:uppercase;letter-spacing:.12em;margin-top:4px}

/* ---- MARQUEE ---- */
.tape{overflow:hidden;padding:1.8rem 0;border-bottom:1px solid rgba(255,255,255,.05);background:var(--dark)}
.tape-in{display:flex;gap:3rem;width:max-content;will-change:transform}
.tape-in span{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--dim);white-space:nowrap;display:flex;align-items:center;gap:1.5rem;transition:color .3s}
.tape-in span:hover{color:var(--accent)}
.tape-in span::after{content:'●';font-size:.4rem;color:var(--accent);opacity:.4}

/* ---- ABOUT SPLIT ---- */
.about{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
.about-txt{display:flex;flex-direction:column;justify-content:center;padding:8% 6% 8% 4%}
.about-txt .tag{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem}
.about-txt h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.5rem);line-height:1.1;margin-bottom:1.5rem;font-weight:700}
.about-txt p{color:var(--gray);font-size:.95rem;line-height:2;margin-bottom:1.5rem;max-width:480px}
.about-img{position:relative;overflow:hidden}
.about-img img{width:100%;height:100%;object-fit:cover}

/* ---- SERVICES ROW (Premium Dynamic) ---- */
.srv-sec{padding:clamp(80px,12vw,160px) 4%;background:var(--dark);position:relative;overflow:hidden}
.srv-sec::before{content:'';position:absolute;top:20%;left:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(255,94,58,.04),transparent 70%);pointer-events:none}
.srv-sec::after{content:'';position:absolute;bottom:10%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(102,126,234,.04),transparent 70%);pointer-events:none}
.srv-head{text-align:center;margin-bottom:5rem;position:relative;z-index:2}
.srv-head .tag{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.srv-head h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4.5vw,3.8rem);font-weight:700}
.srv-list{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;position:relative;z-index:2}
.srv-item{display:flex;align-items:center;gap:1.2rem;padding:2rem 2rem;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);border-radius:16px;transition:all .5s var(--ease);cursor:pointer;text-decoration:none;position:relative;overflow:hidden}
.srv-item::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,94,58,.06),transparent);opacity:0;transition:opacity .4s}
.srv-item:hover::before{opacity:1}
.srv-item:hover{border-color:rgba(255,94,58,.15);transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.3)}
.srv-item:hover .srv-num{color:var(--accent);transform:scale(1.1)}
.srv-item:hover .srv-name{color:#fff}
.srv-item:hover .srv-arrow{opacity:1;transform:translateX(0)}
.srv-num{font-family:'Playfair Display',serif;font-size:2rem;color:var(--dim);font-weight:800;min-width:50px;transition:all .4s var(--ease)}
.srv-name{font-size:1.1rem;font-weight:600;color:var(--off);flex:1;transition:color .3s}
.srv-cat{font-size:.7rem;color:var(--gray);text-transform:uppercase;letter-spacing:.1em;padding:4px 12px;background:rgba(255,255,255,.04);border-radius:6px}
.srv-arrow{font-size:1.4rem;color:var(--accent);opacity:0;transform:translateX(-10px);transition:all .3s var(--ease)}

/* ---- FULL-BLEED PORTFOLIO ---- */
.port-sec{padding:clamp(80px,10vw,140px) 0}
.port-head{text-align:center;padding:0 4%;margin-bottom:4rem}
.port-head .tag{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.port-head h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4.5vw,3.8rem);font-weight:700}
.port-row{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.port-cell{position:relative;overflow:hidden;aspect-ratio:16/10;cursor:pointer}
.port-cell.full{grid-column:span 2;aspect-ratio:21/9}
.port-cell img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease),filter .6s}
.port-cell:hover img{transform:scale(1.07);filter:brightness(.5)}
.port-label{position:absolute;bottom:0;left:0;right:0;padding:2.5rem 3rem;background:linear-gradient(to top,rgba(11,11,11,.9),transparent);opacity:0;transform:translateY(15px);transition:all .5s var(--ease)}
.port-cell:hover .port-label{opacity:1;transform:translateY(0)}
.port-label small{font-size:.7rem;color:var(--accent);text-transform:uppercase;letter-spacing:.15em;font-weight:600}
.port-label h3{font-family:'Playfair Display',serif;font-size:1.5rem;margin-top:4px}

/* ---- CTA BAND ---- */
.cta{padding:clamp(100px,14vw,200px) 4%;text-align:center;position:relative;background:var(--dark)}
.cta::before{content:'';position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(255,94,58,.06),transparent 70%);pointer-events:none}
.cta .tag{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem}
.cta h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,4rem);font-weight:700;margin-bottom:1rem}
.cta p{color:var(--gray);max-width:550px;margin:0 auto 2.5rem;font-size:1.05rem;line-height:1.9}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---- VIDEO ---- */
.vid-sec{padding:clamp(80px,10vw,140px) 4%;background:var(--black)}
.vid-head{text-align:center;margin-bottom:4rem}
.vid-head .tag{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.vid-head h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4.5vw,3.8rem);font-weight:700}
.vid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1200px;margin:0 auto}
.v-card{border-radius:var(--r);overflow:hidden;background:var(--dark);border:1px solid rgba(255,255,255,.04);transition:all .4s var(--ease)}
.v-card:hover{transform:translateY(-6px);border-color:rgba(255,94,58,.15)}
.v-thumb{position:relative;padding-bottom:56.25%;overflow:hidden;cursor:pointer}
.v-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.v-thumb:hover img{transform:scale(1.06)}
.v-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s var(--ease)}
.v-play::after{content:'';border-style:solid;border-width:7px 0 7px 13px;border-color:transparent transparent transparent #fff;margin-left:2px}
.v-thumb:hover .v-play{transform:translate(-50%,-50%) scale(1.12);box-shadow:0 8px 25px rgba(255,94,58,.4)}
.v-card .v-info{padding:1rem 1.2rem}
.v-card .v-info h4{font-size:.88rem;font-weight:500}
.v-card .v-info p{font-size:.75rem;color:var(--dim);margin-top:3px}

/* ---- REVIEWS ---- */
.rev-sec{padding:clamp(80px,10vw,140px) 4%;background:var(--dark)}
.rev-head{text-align:center;margin-bottom:4rem}
.rev-head .tag{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.rev-head h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4.5vw,3.8rem);font-weight:700}
.rev-track-wrap{max-width:1200px;margin:0 auto;overflow:hidden;cursor:grab;-webkit-user-select:none;user-select:none;padding:0 4%}
.rev-track-wrap:active{cursor:grabbing}
.rev-track{display:flex;gap:1.5rem;padding:0;will-change:transform;transition:transform .05s linear}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1200px;margin:0 auto}
.rev-card{min-width:340px;max-width:340px;flex-shrink:0;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);border-radius:var(--r);padding:2.5rem;transition:all .4s var(--ease)}
.rev-card:hover{border-color:rgba(255,94,58,.12);transform:translateY(-4px)}
.rev-card .stars{color:var(--accent);font-size:.85rem;letter-spacing:2px;margin-bottom:1rem}
.rev-card blockquote{color:var(--gray);font-style:italic;font-size:.92rem;line-height:1.9;margin-bottom:1.5rem;padding-left:1.2rem;border-left:2px solid var(--accent)}
.rev-who{display:flex;align-items:center;gap:.8rem}
.rev-av{width:40px;height:40px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:.95rem}
.rev-who strong{font-size:.88rem;display:block}
.rev-who span{font-size:.72rem;color:var(--dim)}
.fv-badge{display:inline-flex;align-items:center;gap:5px;margin-top:1rem;padding:4px 12px;background:rgba(29,191,115,.06);border:1px solid rgba(29,191,115,.15);border-radius:50px;font-size:.68rem;color:#1dbf73;font-weight:500}

/* ---- CONTACT ---- */
.contact-sec{padding:clamp(80px,12vw,160px) 4%;background:var(--black)}
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:6rem;max-width:1200px;margin:0 auto}
.ct-left h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:700;margin-bottom:1rem}
.ct-left>p{color:var(--gray);line-height:2;margin-bottom:2.5rem;max-width:440px}
.ct-row{display:flex;align-items:center;gap:1rem;margin-bottom:1.2rem}
.ct-row i{width:46px;height:46px;border-radius:var(--r);background:var(--mid);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:1rem;flex-shrink:0}
.ct-row strong{display:block;font-size:.85rem}.ct-row a,.ct-row span{font-size:.82rem;color:var(--gray)}
.ct-form{background:var(--dark);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:2.5rem}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{margin-bottom:1rem}
.fg label{display:block;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px;color:var(--dim)}
.fg input,.fg textarea,.fg select{width:100%;padding:13px 16px;background:var(--black);border:1px solid rgba(255,255,255,.06);border-radius:8px;color:#fff;font-family:inherit;font-size:.88rem;transition:border-color .3s}
.fg input:focus,.fg textarea:focus,.fg select:focus{outline:none;border-color:var(--accent)}
.fg textarea{resize:vertical;min-height:120px}
.sub-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:15px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .3s var(--ease)}
.sub-btn:hover{background:#ff7a5c;transform:translateY(-2px);box-shadow:0 8px 24px rgba(255,94,58,.25)}

/* ---- FOOTER ---- */
.foot{background:var(--dark);border-top:1px solid rgba(255,255,255,.05);padding:60px 4% 24px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:3rem;max-width:1200px;margin:0 auto 2.5rem}
.foot-brand p{color:var(--gray);font-size:.95rem;line-height:1.9;margin:.8rem 0 1.2rem;max-width:300px}
.foot-soc{display:flex;gap:10px}
.foot-soc a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:var(--gray);font-size:.9rem;transition:all .3s}
.foot-soc a:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.foot-soc a svg{width:16px;height:16px;fill:currentColor}
.foot-col h5{font-size:.75rem;text-transform:uppercase;letter-spacing:.18em;color:var(--accent);margin-bottom:1rem}
.foot-col a{display:block;font-size:.9rem;color:var(--gray);padding:5px 0;transition:color .3s}
.foot-col a:hover{color:#fff}
.foot-bot{border-top:1px solid rgba(255,255,255,.04);padding-top:1.2rem;text-align:center;font-size:.82rem;color:#fff;max-width:1200px;margin:0 auto}

/* ---- MODAL ---- */
.m-bg{position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(10px);z-index:2000;display:none;align-items:center;justify-content:center}
.m-bg.on{display:flex}
.m-box{background:var(--dark);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:2.5rem;max-width:520px;width:92%;position:relative}
.m-x{position:absolute;top:14px;right:18px;background:none;border:none;color:var(--dim);font-size:1.6rem;cursor:pointer;transition:color .3s}.m-x:hover{color:var(--accent)}

/* ---- VIRTUAL TOUR EMBEDDED ---- */
.tour-sec{padding:clamp(80px,10vw,140px) 4%;background:var(--dark)}
.tour-head{text-align:center;margin-bottom:4rem}
.tour-head .tag{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.tour-head h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4.5vw,3.8rem);font-weight:700;margin-bottom:.8rem}
.tour-head p{color:var(--gray);font-size:1rem;max-width:500px;margin:0 auto}
.tour-split{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:1300px;margin:0 auto}
.tour-card{border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.06);background:var(--mid);transition:border-color .4s}
.tour-card:hover{border-color:rgba(255,94,58,.15)}
.tour-preview{position:relative;aspect-ratio:16/9;overflow:hidden;cursor:pointer}
.tour-preview iframe{width:100%;height:100%;border:none}
.tour-poster{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .8s var(--ease),filter .4s}
.tour-preview:hover .tour-poster{transform:scale(1.04);filter:brightness(.4)}
.tour-play-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2;pointer-events:none}
.tour-play-btn{width:72px;height:72px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:#fff;margin-bottom:1rem;transition:transform .3s var(--ease),box-shadow .3s}
.tour-preview:hover .tour-play-btn{transform:scale(1.1);box-shadow:0 10px 30px rgba(255,94,58,.4)}
.tour-play-overlay h3{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:600;color:#fff}
.tour-play-overlay p{font-size:.8rem;color:var(--gray);margin-top:2px}
.tour-meta{display:flex;justify-content:space-between;padding:1rem 1.5rem;font-size:.75rem;color:var(--dim)}
.tour-meta span{display:flex;align-items:center;gap:6px}
.tour-meta i{color:var(--accent);font-size:.7rem}

/* ---- SERVICE BODY (description under name) ---- */
.srv-body{flex:1}
.srv-body .srv-name{display:block}
.srv-desc{display:block;font-size:.82rem;color:var(--gray);margin-top:6px;line-height:1.7;max-width:500px;transition:color .3s}
.srv-item:hover .srv-desc{color:var(--off)}

/* ---- BENTO VIDEO GRID ---- */
.bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:8px;max-width:1200px;margin:0 auto;border-radius:var(--r);overflow:hidden}
.b-cell{position:relative;overflow:hidden;cursor:pointer;border-radius:10px}
.b-cell img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.b-cell:hover img{transform:scale(1.08)}
.b-cell .v-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;opacity:.8;transition:all .3s}
.b-cell:hover .v-play{opacity:1;transform:translate(-50%,-50%) scale(1.15);box-shadow:0 6px 20px rgba(255,94,58,.35)}
.b-label{position:absolute;bottom:0;left:0;right:0;padding:12px 16px;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);font-size:.82rem;font-weight:500}
.b-tall{grid-row:span 2}
.b-wide{grid-column:span 2}

/* ---- LATEST NEWS CAROUSEL ---- */
.news-sec{padding:clamp(60px,8vw,100px) 0;background:var(--black);overflow:hidden}
.news-head{padding:0 4%;margin-bottom:2.5rem}
.news-head h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.5rem);font-weight:800;text-transform:uppercase;letter-spacing:.02em}
.news-track-wrap{max-width:1200px;margin:0 auto;overflow:hidden;cursor:grab;-webkit-user-select:none;user-select:none;padding:0 4%}
.news-track-wrap:active{cursor:grabbing}
.news-track{display:flex;gap:1.5rem;padding:0;will-change:transform;transition:transform .05s linear}
.news-card{min-width:380px;max-width:380px;background:var(--mid);border:1px solid rgba(255,255,255,.05);border-radius:14px;overflow:hidden;flex-shrink:0;transition:border-color .3s}
.news-card:hover{border-color:rgba(255,94,58,.12)}
.news-img{height:200px;overflow:hidden}
.news-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.news-card:hover .news-img img{transform:scale(1.05)}
.news-body{padding:1.2rem 1.5rem 1.5rem}
.news-tag{display:inline-block;padding:3px 10px;border-radius:4px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;background:#f0a500;color:#000;margin-bottom:.6rem}
.news-card:nth-child(2) .news-tag{background:var(--accent)}
.news-card:nth-child(3) .news-tag{background:#667eea;color:#fff}
.news-card:nth-child(4) .news-tag{background:#1dbf73;color:#fff}
.news-card:nth-child(5) .news-tag{background:#ff6b6b;color:#fff}
.news-card:nth-child(6) .news-tag{background:#e94560;color:#fff}
.news-body h3{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:600;margin-bottom:.5rem;color:#fff}
.news-body p{font-size:.82rem;color:var(--gray);line-height:1.8}

/* ---- REVEAL SYSTEM (IntersectionObserver — bulletproof) ---- */
.rv{opacity:0;transform:translateY(40px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv-l{opacity:0;transform:translateX(-40px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv-r{opacity:0;transform:translateX(40px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv-s{opacity:0;transform:scale(.92);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.show,.rv-l.show,.rv-r.show,.rv-s.show{opacity:1;transform:none}
.rv-d1{transition-delay:.1s}.rv-d2{transition-delay:.2s}.rv-d3{transition-delay:.3s}
.rv-d4{transition-delay:.4s}.rv-d5{transition-delay:.5s}

/* ---- RESPONSIVE ---- */
@media(max-width:1024px){.about{grid-template-columns:1fr}.about-img{height:50vh}.port-row{grid-template-columns:1fr}.port-cell.full{grid-column:span 1}.rev-grid,.vid-grid{grid-template-columns:1fr 1fr}.contact-wrap{grid-template-columns:1fr}.foot-grid{grid-template-columns:1fr 1fr}.tour-split{grid-template-columns:1fr}.bento{grid-template-columns:1fr 1fr}.b-tall{grid-row:span 2}.b-wide{grid-column:span 2}}
@media(max-width:768px){
  .cur,.cur-d{display:none}
  .burger{display:flex;position:relative;z-index:1002}
  .n-links{position:fixed;top:0;right:0;width:100%;height:100vh;height:100dvh;background:rgba(11,11,11,.98);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);flex-direction:column;align-items:flex-start;padding:90px 2rem 2rem;transition:transform .4s var(--ease),opacity .4s var(--ease);transform:translateX(100%);opacity:0;z-index:1000;overflow-y:auto;-webkit-overflow-scrolling:touch}
  .n-links.on{transform:translateX(0);opacity:1}
  .n-links a{padding:14px 0;border-bottom:1px solid rgba(255,255,255,.06);width:100%;font-size:.95rem;text-transform:none;letter-spacing:0;color:rgba(255,255,255,.9)}
  .n-links a:hover,.n-links a.on{color:var(--accent)}
  .n-est{margin-top:12px;text-align:center;justify-content:center;display:inline-flex;width:auto;padding:8px 20px;font-size:.8rem;border-bottom:none !important}
  .n-dd{width:100%}
  .n-dd>a{display:flex;justify-content:space-between;align-items:center;width:100%}
  .n-dd-p{position:static;transform:none;opacity:1;visibility:visible;min-width:100%;background:rgba(255,255,255,.02);border:none;backdrop-filter:none;padding:4px 0 8px 1rem;display:none;border-radius:8px;margin:4px 0}
  .n-dd-p a{padding:12px 14px;border-bottom:none;font-size:.88rem;color:rgba(255,255,255,.7)}
  .n-dd-p a i{width:20px;color:var(--accent)}
  .n-dd.open .n-dd-p{display:block}
  .hero h1{font-size:clamp(2.5rem,10vw,4.5rem)}
  .hero-nums{position:static;margin-top:2.5rem;gap:2rem;flex-wrap:wrap}
  .hero-nums .v{font-size:2rem}
  .rev-grid,.vid-grid{grid-template-columns:1fr}
  .f2{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:1.5rem}
  .foot-brand{grid-column:span 2}
  .foot-brand p{font-size:.85rem;max-width:100%}
  .foot-col:nth-child(4){grid-column:span 2}
  .foot{padding:40px 4% 90px}
  .srv-item{flex-wrap:wrap;gap:.5rem}
  .srv-list{grid-template-columns:1fr}
  .srv-cat{display:none}
  .port-row{gap:2px}
  .tour-split{grid-template-columns:1fr}
  .bento{grid-template-columns:1fr;grid-auto-rows:180px}
  .b-tall,.b-wide{grid-row:span 1;grid-column:span 1}
  .news-card{min-width:300px;max-width:300px}
}

/* ---- SCROLL PROGRESS BAR ---- */
.scroll-prog{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--accent),#ff8a65);z-index:10001;width:0;transition:none;pointer-events:none}

/* ---- BACK TO TOP ---- */
.btt{position:fixed;bottom:100px;right:28px;width:46px;height:46px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:1rem;cursor:pointer;z-index:999;opacity:0;visibility:hidden;transform:translateY(20px);transition:all .4s var(--ease);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(255,94,58,.3)}
.btt.show{opacity:1;visibility:visible;transform:translateY(0)}
.btt:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(255,94,58,.45)}

/* ---- FLOATING WHATSAPP ---- */
.wa-float{position:fixed;bottom:32px;right:28px;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;font-size:1.6rem;display:flex;align-items:center;justify-content:center;z-index:999;cursor:pointer;text-decoration:none;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:all .3s var(--ease);animation:waPulse 2s ease-in-out infinite}
.wa-float:hover{transform:scale(1.12);box-shadow:0 8px 30px rgba(37,211,102,.6)}
.wa-tooltip{position:absolute;right:70px;top:50%;transform:translateY(-50%);background:var(--dark);color:#fff;padding:8px 16px;border-radius:8px;font-size:.78rem;white-space:nowrap;opacity:0;visibility:hidden;transition:all .3s;pointer-events:none;border:1px solid rgba(255,255,255,.08)}
.wa-float:hover .wa-tooltip{opacity:1;visibility:visible}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)}50%{box-shadow:0 4px 30px rgba(37,211,102,.7),0 0 0 12px rgba(37,211,102,.1)}}

/* ---- HERO TYPING ---- */
.hero-typed{color:var(--accent);font-style:italic;font-weight:500;position:relative}
.hero-typed::after{content:'|';animation:blink 1s infinite;margin-left:2px;color:var(--accent)}
@keyframes blink{0%,50%{opacity:1}51%,100%{opacity:0}}

/* ---- LIGHTBOX ---- */
.lb{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:5000;display:none;align-items:center;justify-content:center;backdrop-filter:blur(10px)}
.lb.on{display:flex}
.lb img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:8px;animation:lbIn .4s var(--ease)}
@keyframes lbIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
.lb-close{position:absolute;top:20px;right:28px;background:none;border:none;color:rgba(255,255,255,.6);font-size:2rem;cursor:pointer;transition:color .3s;z-index:5001}
.lb-close:hover{color:#fff}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.06);border:none;color:#fff;width:52px;height:52px;border-radius:50%;font-size:1.2rem;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px)}
.lb-nav:hover{background:var(--accent)}
.lb-prev{left:20px}
.lb-next{right:20px}
.lb-count{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-size:.82rem;color:var(--gray);letter-spacing:.1em}

/* ---- PROCESS / HOW WE WORK ---- */
.proc-sec{padding:clamp(80px,10vw,140px) 4%;background:var(--dark);position:relative;overflow:hidden}
.proc-sec::before{content:'';position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(255,94,58,.04),transparent 65%);pointer-events:none}
.proc-head{text-align:center;margin-bottom:5rem;position:relative;z-index:2}
.proc-head .tag{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.proc-head h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4.5vw,3.8rem);font-weight:700}
.proc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2rem;max-width:1200px;margin:0 auto;position:relative;z-index:2}
.proc-step{text-align:center;position:relative;padding:2rem 1rem}
.proc-step::before{content:'';position:absolute;top:40px;right:-50%;width:100%;height:2px;background:linear-gradient(90deg,var(--accent),rgba(255,94,58,.1));pointer-events:none}
.proc-step:last-child::before{display:none}
.proc-icon{width:72px;height:72px;border-radius:50%;background:rgba(255,94,58,.08);border:2px solid rgba(255,94,58,.15);display:flex;align-items:center;justify-content:center;margin:0 auto 1.2rem;font-size:1.4rem;color:var(--accent);transition:all .4s var(--ease);position:relative;z-index:2}
.proc-step:hover .proc-icon{background:var(--accent);color:#fff;transform:scale(1.1);box-shadow:0 8px 30px rgba(255,94,58,.3);border-color:var(--accent)}
.proc-num{font-family:'Playfair Display',serif;font-size:.7rem;font-weight:700;color:var(--accent);letter-spacing:.15em;margin-bottom:.5rem}
.proc-step h4{font-size:.95rem;font-weight:600;margin-bottom:.4rem;color:#fff}
.proc-step p{font-size:.78rem;color:var(--gray);line-height:1.7}

/* ---- TOAST ---- */
.toast{position:fixed;top:90px;right:-400px;background:var(--dark);border:1px solid rgba(29,191,115,.2);border-radius:14px;padding:16px 24px;display:flex;align-items:center;gap:12px;z-index:3000;transition:right .5s var(--ease);box-shadow:0 10px 40px rgba(0,0,0,.5);max-width:380px}
.toast.show{right:28px}
.toast-icon{width:40px;height:40px;border-radius:50%;background:rgba(29,191,115,.1);display:flex;align-items:center;justify-content:center;color:#1dbf73;font-size:1.1rem;flex-shrink:0}
.toast-body strong{display:block;font-size:.85rem;margin-bottom:2px}
.toast-body span{font-size:.78rem;color:var(--gray)}
.toast-x{background:none;border:none;color:var(--dim);font-size:1.1rem;cursor:pointer;margin-left:8px;transition:color .3s}
.toast-x:hover{color:var(--accent)}

@media(max-width:768px){
  .proc-grid{grid-template-columns:1fr 1fr;gap:1.5rem}
  .proc-step::before{display:none}
  .wa-tooltip{display:none}
  .btt{bottom:96px;right:16px;width:42px;height:42px}
  .wa-float{bottom:28px;right:16px;width:50px;height:50px;font-size:1.4rem}
}
@media(max-width:480px){
  .proc-grid{grid-template-columns:1fr}
}

/* ---- BRAND LOGOS MARQUEE ---- */
.logos-sec{padding:clamp(40px,6vw,70px) 0;background:var(--black);border-top:1px solid rgba(255,255,255,.03);border-bottom:1px solid rgba(255,255,255,.03);overflow:hidden}
.logos-head{text-align:center;margin-bottom:2rem}
.logos-head span{font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}
.logos-track{display:flex;gap:4rem;animation:marquee 30s linear infinite;width:max-content}
.logos-track:hover{animation-play-state:paused}
.logo-item{display:flex;align-items:center;gap:10px;font-size:.85rem;font-weight:500;color:var(--dim);white-space:nowrap;opacity:.5;transition:opacity .3s;flex-shrink:0}
.logo-item:hover{opacity:1}
.logo-item i,.logo-item svg{font-size:1.4rem;color:var(--gray)}
.logo-item img{height:28px;filter:brightness(0) invert(.4);transition:filter .3s}
.logo-item:hover img{filter:brightness(0) invert(.8)}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ---- BEFORE/AFTER SLIDER ---- */
.ba-sec{padding:clamp(60px,8vw,100px) 4%;background:var(--black)}
.ba-head{text-align:center;margin-bottom:3rem}
.ba-head .tag{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.ba-head h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,3rem);font-weight:700}
.ba-wrap{max-width:900px;margin:0 auto;position:relative;overflow:hidden;border-radius:16px;border:1px solid rgba(255,255,255,.06);aspect-ratio:16/9;cursor:col-resize;user-select:none;-webkit-user-select:none}
.ba-wrap img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}
.ba-after{clip-path:inset(0 0 0 50%)}
.ba-line{position:absolute;top:0;left:50%;width:3px;height:100%;background:var(--accent);z-index:5;pointer-events:none;transform:translateX(-50%)}
.ba-line::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(255,94,58,.4)}
.ba-line::before{content:'⟨ ⟩';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:.85rem;font-weight:700;z-index:6;letter-spacing:6px}
.ba-label{position:absolute;bottom:16px;padding:6px 14px;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);border-radius:6px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;z-index:3}
.ba-label-before{left:16px}
.ba-label-after{right:16px}

/* ---- SVG WAVE DIVIDER ---- */
.wave-div{height:80px;width:100%;position:relative;overflow:hidden}
.wave-div svg{position:absolute;bottom:0;width:100%;height:100%}
.wave-div.flip{transform:scaleY(-1)}

/* ---- MOBILE BOTTOM NAV ---- */
.mob-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:rgba(17,17,17,.97);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.06);z-index:1000;padding:8px 0 max(8px,env(safe-area-inset-bottom))}
.mob-nav-grid{display:flex;justify-content:space-around;align-items:center}
.mob-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;text-decoration:none;color:var(--dim);font-size:.6rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;transition:color .3s;padding:4px 8px}
.mob-nav-item i{font-size:1.1rem;transition:color .3s}
.mob-nav-item.active,.mob-nav-item:hover{color:var(--accent)}
.mob-nav-item.active i,.mob-nav-item:hover i{color:var(--accent)}

@media(max-width:768px){
  .mob-nav{display:block}
  .wa-float{bottom:76px}
  .btt{bottom:140px}
  body{padding-bottom:70px}
}

/* ---- 404 PAGE ---- */
.e404{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}
.e404 h1{font-family:'Playfair Display',serif;font-size:clamp(6rem,15vw,12rem);font-weight:900;background:linear-gradient(135deg,var(--accent),#ff8a65);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.e404 h2{font-family:'Playfair Display',serif;font-size:1.6rem;margin:1rem 0}
.e404 p{color:var(--gray);max-width:400px;margin:0 auto 2rem;line-height:1.9}
.e404 a{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:var(--accent);color:#fff;border-radius:10px;font-weight:600;text-decoration:none;transition:all .3s}
.e404 a:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(255,94,58,.3)}

/* ---- CTA BANNER ---- */
.cta-sec{padding:clamp(60px,8vw,100px) 4%;background:var(--black)}
.cta-banner{max-width:1100px;margin:0 auto;background:linear-gradient(135deg,rgba(255,94,58,.08),rgba(255,94,58,.02));border:1px solid rgba(255,94,58,.1);border-radius:24px;padding:clamp(2.5rem,5vw,4rem);display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:center;position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;right:-80px;top:-80px;width:250px;height:250px;border-radius:50%;background:rgba(255,94,58,.06)}
.cta-banner::after{content:'';position:absolute;left:-40px;bottom:-40px;width:180px;height:180px;border-radius:50%;background:rgba(255,94,58,.03)}
.cta-text{position:relative;z-index:2}
.cta-text h2{font-family:'Playfair Display',serif;font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700;margin-bottom:1rem;line-height:1.3}
.cta-text h2 i{color:var(--accent);font-style:italic}
.cta-text p{color:var(--gray);font-size:.92rem;line-height:1.9;margin-bottom:1.5rem}
.cta-perks{display:flex;gap:2rem;flex-wrap:wrap}
.cta-perks span{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--off)}
.cta-perks i{color:var(--accent);font-size:.7rem}
.cta-form{position:relative;z-index:2;display:flex;flex-direction:column;gap:1rem;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:2rem}
.cta-form form{display:flex;flex-direction:column;gap:1rem}
.cta-form input{background:var(--mid);border:1px solid rgba(255,255,255,.06);padding:14px 18px;border-radius:10px;color:#fff;font-size:.88rem;outline:none;transition:border-color .3s;font-family:'Inter',sans-serif}
.cta-form input:focus{border-color:var(--accent)}
.cta-form button{padding:14px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .3s;font-family:'Inter',sans-serif}
.cta-form button:hover{background:#ff7a5c;transform:translateY(-2px);box-shadow:0 8px 25px rgba(255,94,58,.3)}
.cta-form small{text-align:center;color:var(--dim);font-size:.72rem}
@media(max-width:768px){.cta-banner{grid-template-columns:1fr}.cta-perks{gap:1rem}}

/* ---- COOKIE CONSENT ---- */
.cookie-bar{position:fixed;bottom:0;left:0;right:0;background:rgba(17,17,17,.97);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.06);padding:16px 4%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;z-index:9999;transform:translateY(100%);transition:transform .5s cubic-bezier(.4,0,.2,1);flex-wrap:wrap}
.cookie-bar.show{transform:translateY(0)}
.cookie-bar p{color:var(--gray);font-size:.82rem;line-height:1.7;flex:1;min-width:250px}
.cookie-bar p a{color:var(--accent);text-decoration:underline}
.cookie-btns{display:flex;gap:.6rem;flex-shrink:0}
.cookie-btn{padding:9px 20px;border-radius:8px;font-size:.78rem;font-weight:600;cursor:pointer;border:none;font-family:'Inter',sans-serif;transition:all .3s}
.cookie-accept{background:var(--accent);color:#fff}
.cookie-accept:hover{background:#ff7a5c;transform:translateY(-1px)}
.cookie-decline{background:transparent;color:var(--gray);border:1px solid rgba(255,255,255,.1)}
.cookie-decline:hover{border-color:var(--gray)}

/* ---- ACCESSIBILITY ---- */
.skip-link{position:absolute;top:-100%;left:1rem;padding:10px 20px;background:var(--accent);color:#fff;border-radius:0 0 8px 8px;font-weight:600;font-size:.85rem;z-index:10001;transition:top .3s}
.skip-link:focus{top:0}
*:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
@media(max-width:768px){
  .cookie-bar{bottom:60px;padding:12px 4%}
}

/* ---- LIVE TOUR DEMO ---- */
.demo-sec{padding:clamp(60px,8vw,100px) 4%;background:var(--dark)}
.demo-head{text-align:center;margin-bottom:2.5rem}
.demo-head h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700}
.demo-frame{max-width:1000px;margin:0 auto;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.06);box-shadow:0 20px 60px rgba(0,0,0,.4);position:relative;aspect-ratio:16/9;background:var(--mid)}
.demo-frame iframe{width:100%;height:100%;border:none}
.demo-note{text-align:center;margin-top:1.5rem;display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}
.demo-note span{font-size:.78rem;color:var(--dim);display:flex;align-items:center;gap:6px}
.demo-note i{color:var(--accent);font-size:.7rem}

/* ---- CASE STUDY PAGE ---- */
.cs-hero{padding:200px 4% 80px;text-align:center;background:linear-gradient(to bottom,rgba(11,11,11,.3),var(--black));position:relative}
.cs-hero::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.6)}
.cs-hero-in{position:relative;z-index:2;max-width:800px;margin:0 auto}
.cs-hero h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,3.5rem);font-weight:800;margin-bottom:1rem}
.cs-hero p{color:var(--gray);font-size:1rem;line-height:1.9}
.cs-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.5rem;max-width:900px;margin:-40px auto 0;padding:0 4%;position:relative;z-index:3}
.cs-info-card{background:var(--mid);border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:1.5rem;text-align:center}
.cs-info-card i{color:var(--accent);font-size:1.3rem;margin-bottom:.8rem;display:block}
.cs-info-card small{color:var(--dim);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;display:block;margin-bottom:.3rem}
.cs-info-card strong{color:#fff;font-size:.92rem}
.cs-body{max-width:900px;margin:0 auto;padding:60px 4% 80px}
.cs-block{margin-bottom:3rem}
.cs-block h2{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--accent);margin-bottom:1rem;position:relative;padding-left:18px}
.cs-block h2::before{content:'';position:absolute;left:0;top:4px;bottom:4px;width:3px;background:var(--accent);border-radius:2px}
.cs-block p{color:var(--gray);font-size:.95rem;line-height:2.2;margin-bottom:1rem}
.cs-gallery{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:2rem 0}
.cs-gallery img{width:100%;height:300px;object-fit:cover;border-radius:12px;border:1px solid rgba(255,255,255,.05)}
.cs-quote{background:var(--mid);border-left:3px solid var(--accent);border-radius:0 12px 12px 0;padding:2rem;margin:2rem 0}
.cs-quote blockquote{color:var(--off);font-size:1rem;font-style:italic;line-height:1.9;margin-bottom:1rem}
.cs-quote cite{color:var(--dim);font-size:.82rem}
@media(max-width:768px){.cs-gallery{grid-template-columns:1fr}.cs-info{grid-template-columns:1fr 1fr}}
