@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Inter:wght@300;400;500;600;700&display=swap');
:root{--navy:#0a1628;--navy-light:#132038;--charcoal:#2a2d35;--white:#ffffff;--off-white:#f4f5f7;--platinum:#c0c5ce;--gold:#c9a84c;--gold-light:#d4b96a;--gold-dark:#b08d3a;--silver:#8a919c;--text:#e8e9ec;--text-dark:#1a1d25;--glass:rgba(255,255,255,0.06);--glass-border:rgba(255,255,255,0.1);--shadow:0 8px 32px rgba(0,0,0,0.3);--shadow-lg:0 20px 60px rgba(0,0,0,0.4);--radius:12px;--transition:0.4s cubic-bezier(0.25,0.46,0.45,0.94)}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter',sans-serif;background:var(--navy);color:var(--text);line-height:1.7;overflow-x:hidden}
h1,h2,h3,h4,h5{font-family:'Playfair Display',serif;font-weight:600;line-height:1.25;color:var(--white)}
a{text-decoration:none;color:inherit;transition:var(--transition)}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
/* ACCESS PAGE */
.access-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.access-bg{position:absolute;inset:0;z-index:0}
.access-bg img{width:100%;height:100%;object-fit:cover;object-position:center 20%;filter:blur(6px) brightness(0.3)}
.access-box{position:relative;z-index:2;width:420px;max-width:90vw;background:rgba(10,22,40,0.65);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-border);border-radius:20px;padding:48px 40px;text-align:center;box-shadow:var(--shadow-lg);animation:fadeScale .8s ease}
@keyframes fadeScale{from{opacity:0;transform:scale(.92) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
.access-box .monogram{width:64px;height:64px;border-radius:50%;border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-family:'Playfair Display',serif;font-size:24px;color:var(--gold);font-weight:700}
.access-box h1{font-size:28px;margin-bottom:8px;letter-spacing:1px}
.access-box p{color:var(--platinum);font-size:14px;margin-bottom:32px}
.input-wrap{position:relative;margin-bottom:24px}
.input-wrap input{width:100%;padding:14px 48px 14px 18px;background:rgba(255,255,255,0.06);border:1px solid var(--glass-border);border-radius:10px;color:var(--white);font-size:15px;font-family:'Inter',sans-serif;outline:none;transition:var(--transition)}
.input-wrap input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,0.15)}
.input-wrap input::placeholder{color:var(--silver)}
.toggle-pass{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--silver);cursor:pointer;font-size:18px;transition:var(--transition)}
.toggle-pass:hover{color:var(--gold)}
.access-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--navy);font-weight:600;font-size:15px;border:none;border-radius:10px;cursor:pointer;font-family:'Inter',sans-serif;letter-spacing:.5px;transition:var(--transition);position:relative;overflow:hidden}
.access-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(201,168,76,0.35)}
.access-btn::after{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,0.2);border-radius:50%;transform:translate(-50%,-50%);transition:.6s}
.access-btn:active::after{width:300px;height:300px;opacity:0}
.access-error{color:#e74c3c;font-size:13px;margin-top:16px;display:none;animation:shake .4s ease}
.access-error.show{display:block}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
/* NAV */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:18px 0;transition:var(--transition)}
.navbar.scrolled{background:rgba(10,22,40,0.95);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:12px 0;box-shadow:0 2px 20px rgba(0,0,0,0.3)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1280px;margin:0 auto;padding:0 32px}
.nav-brand{font-family:'Playfair Display',serif;font-size:20px;font-weight:600;color:var(--white);letter-spacing:.5px}
.nav-brand span{color:var(--gold)}
.nav-links{display:flex;gap:28px;list-style:none}
.nav-links a{color:var(--platinum);font-size:13px;font-weight:500;letter-spacing:.8px;text-transform:uppercase;position:relative;padding:4px 0}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--gold);transition:var(--transition)}
.nav-links a:hover,.nav-links a.active{color:var(--white)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:24px;height:2px;background:var(--white);transition:var(--transition)}
/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center top}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,22,40,0.85) 0%,rgba(10,22,40,0.5) 50%,rgba(10,22,40,0.7) 100%);z-index:1}
.hero-content{position:relative;z-index:2;max-width:720px;padding:0 32px}
.hero-label{display:inline-block;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold);padding:6px 16px;border-radius:30px;margin-bottom:20px}
.hero h1{font-size:clamp(36px,5vw,64px);margin-bottom:12px;letter-spacing:1px}
.hero h1 span{color:var(--gold)}
.hero .subtitle{font-size:clamp(14px,2vw,18px);color:var(--platinum);font-weight:300;margin-bottom:40px;letter-spacing:1px}
.hero-stats{display:flex;gap:40px;flex-wrap:wrap}
.stat-item{text-align:center}
.stat-num{font-family:'Playfair Display',serif;font-size:42px;font-weight:700;color:var(--gold);display:block}
.stat-label{font-size:12px;color:var(--platinum);text-transform:uppercase;letter-spacing:1.5px;margin-top:4px}
/* SECTIONS */
.section{padding:100px 0}
.section-dark{background:var(--navy-light)}
.section-header{text-align:center;margin-bottom:64px}
.section-label{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;display:block}
.section-title{font-size:clamp(28px,3.5vw,44px);margin-bottom:16px}
.section-line{width:60px;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-light));margin:0 auto;border-radius:2px}
.section-desc{color:var(--platinum);max-width:600px;margin:20px auto 0;font-size:15px}
/* CARDS */
.card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:32px;transition:var(--transition)}
.card:hover{transform:translateY(-6px);border-color:rgba(201,168,76,0.3);box-shadow:var(--shadow)}
.card-icon{width:52px;height:52px;border-radius:12px;background:linear-gradient(135deg,rgba(201,168,76,0.15),rgba(201,168,76,0.05));display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-size:24px;color:var(--gold)}
.card h3{font-size:20px;margin-bottom:10px}
.card p{color:var(--platinum);font-size:14px;line-height:1.7}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
/* PAGE BANNER */
.page-banner{position:relative;height:50vh;min-height:360px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.page-banner .hero-bg img{object-position:center 20%}
.page-banner .hero-overlay{background:linear-gradient(to bottom,rgba(10,22,40,0.7),rgba(10,22,40,0.9))}
.page-banner-content{position:relative;z-index:2;text-align:center}
.page-banner h1{font-size:clamp(32px,4vw,52px);margin-bottom:12px}
.page-banner p{color:var(--platinum);font-size:16px;letter-spacing:1px}
/* INTRO ROW */
.intro-row{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:center}
.intro-img{border-radius:var(--radius);overflow:hidden;position:relative}
.intro-img img{width:100%;height:100%;object-fit:cover;object-position:center top}
.intro-img::after{content:'';position:absolute;inset:0;border:2px solid var(--gold);border-radius:var(--radius);opacity:.3}
.intro-text .lead{font-size:18px;color:var(--white);line-height:1.8;margin-bottom:20px;font-family:'Playfair Display',serif;font-style:italic}
.intro-text p{color:var(--platinum);margin-bottom:16px;font-size:15px}
/* QUOTE */
.quote-block{position:relative;padding:60px;background:linear-gradient(135deg,var(--navy-light),var(--navy));border:1px solid var(--glass-border);border-radius:var(--radius);text-align:center;margin:60px 0}
.quote-block::before{content:'\201C';position:absolute;top:10px;left:30px;font-size:120px;font-family:'Playfair Display',serif;color:var(--gold);opacity:.2;line-height:1}
.quote-block blockquote{font-family:'Playfair Display',serif;font-size:clamp(18px,2.5vw,26px);font-style:italic;color:var(--white);line-height:1.6;max-width:800px;margin:0 auto}
.quote-block cite{display:block;margin-top:20px;color:var(--gold);font-size:14px;font-style:normal;letter-spacing:1px}
/* TIMELINE */
.timeline{position:relative;padding-left:40px}
.timeline::before{content:'';position:absolute;left:15px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--gold),var(--gold-dark),transparent)}
.timeline-item{position:relative;margin-bottom:48px;padding-left:32px}
.timeline-item::before{content:'';position:absolute;left:-32px;top:6px;width:14px;height:14px;border-radius:50%;background:var(--gold);border:3px solid var(--navy);z-index:1}
.timeline-item h3{font-size:20px;margin-bottom:6px}
.timeline-item .year{color:var(--gold);font-size:13px;font-weight:600;letter-spacing:1px;margin-bottom:8px;display:block}
.timeline-item p{color:var(--platinum);font-size:14px}
/* GALLERY */
.masonry{columns:3;column-gap:20px}
.masonry-item{break-inside:avoid;margin-bottom:20px;border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer}
.masonry-item img{width:100%;display:block;transition:var(--transition);object-fit:cover;object-position:center top}
.masonry-item:hover img{transform:scale(1.05)}
.masonry-item::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,40,0.5),transparent);opacity:0;transition:var(--transition)}
.masonry-item:hover::after{opacity:1}
/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,0.92);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;opacity:0;transition:var(--transition)}
.lightbox.active{display:flex;opacity:1}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:8px;box-shadow:var(--shadow-lg)}
.lightbox-close{position:absolute;top:24px;right:32px;background:none;border:none;color:var(--white);font-size:32px;cursor:pointer;z-index:10;transition:var(--transition)}
.lightbox-close:hover{color:var(--gold);transform:rotate(90deg)}
/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:13px;color:var(--platinum);margin-bottom:6px;letter-spacing:.5px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:13px 16px;background:var(--glass);border:1px solid var(--glass-border);border-radius:8px;color:var(--white);font-family:'Inter',sans-serif;font-size:14px;outline:none;transition:var(--transition)}
.form-group input:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group textarea{height:120px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.submit-btn{padding:14px 40px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--navy);font-weight:600;font-size:14px;border:none;border-radius:8px;cursor:pointer;font-family:'Inter',sans-serif;transition:var(--transition)}
.submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(201,168,76,0.3)}
.contact-info-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:28px;margin-bottom:20px;display:flex;align-items:center;gap:16px;transition:var(--transition)}
.contact-info-card:hover{border-color:rgba(201,168,76,0.3)}
.contact-info-card .icon{width:44px;height:44px;border-radius:10px;background:rgba(201,168,76,0.12);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--gold);flex-shrink:0}
.contact-info-card h4{font-size:15px;margin-bottom:2px}
.contact-info-card p,.contact-info-card a{color:var(--platinum);font-size:14px}
.contact-info-card a:hover{color:var(--gold)}
.social-row{display:flex;gap:12px;margin-top:24px}
.social-row a{width:42px;height:42px;border-radius:10px;background:var(--glass);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;color:var(--platinum);font-size:16px;transition:var(--transition)}
.social-row a:hover{background:var(--gold);color:var(--navy);border-color:var(--gold);transform:translateY(-3px)}
/* FOOTER */
.footer{background:var(--charcoal);padding:40px 0;border-top:1px solid var(--glass-border)}
.footer-inner{text-align:center}
.footer p{color:var(--silver);font-size:13px;margin-bottom:8px}
.footer a{color:var(--gold);transition:var(--transition)}
.footer a:hover{color:var(--gold-light)}
.footer .social-row{justify-content:center;margin-top:16px;margin-bottom:12px}
.footer-sep{color:var(--silver);margin:0 8px}
/* CTA BUTTON */
.cta-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--navy);font-weight:600;font-size:14px;border-radius:8px;transition:var(--transition);letter-spacing:.5px}
.cta-btn:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(201,168,76,0.3)}
.cta-outline{background:transparent;border:1.5px solid var(--gold);color:var(--gold)}
.cta-outline:hover{background:var(--gold);color:var(--navy)}
/* ALTERNATING LAYOUT */
.alt-row{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-bottom:60px}
.alt-row.reverse{direction:rtl}
.alt-row.reverse>*{direction:ltr}
.alt-row img{width:100%;height:360px;object-fit:cover;object-position:center top;border-radius:var(--radius)}
/* EXPERTISE ICONS */
.expertise-card{text-align:center;padding:40px 28px}
.expertise-card .card-icon{margin:0 auto 20px}
/* PHILOSOPHY */
.philosophy-card{padding:40px;position:relative;overflow:hidden}
.philosophy-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(to bottom,var(--gold),transparent);border-radius:2px}
.philosophy-card .num{font-family:'Playfair Display',serif;font-size:48px;color:rgba(201,168,76,0.15);font-weight:700;position:absolute;top:16px;right:24px}
/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(30px);transition:.7s cubic-bezier(.25,.46,.45,.94)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:.7s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:.7s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}
/* PAGE TRANSITION OVERLAY */
.page-loader{position:fixed;inset:0;z-index:10000;background:var(--navy);display:flex;align-items:center;justify-content:center;transition:opacity .5s;pointer-events:none}
.page-loader.hidden{opacity:0}
.loader-ring{width:40px;height:40px;border:3px solid var(--glass-border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* RESPONSIVE */
@media(max-width:1024px){
.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
.intro-row,.alt-row,.contact-grid{grid-template-columns:1fr}
.masonry{columns:2}
.alt-row.reverse{direction:ltr}
}
@media(max-width:768px){
.nav-links{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:var(--navy);flex-direction:column;padding:80px 32px;gap:20px;transition:var(--transition);box-shadow:var(--shadow-lg)}
.nav-links.open{right:0}
.hamburger{display:flex}
.hero-content{padding:0 20px}
.hero-stats{gap:24px}
.stat-num{font-size:32px}
.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
.masonry{columns:1}
.section{padding:60px 0}
.quote-block{padding:32px}
.page-banner{height:40vh;min-height:280px}
.form-row{grid-template-columns:1fr}
.hero{min-height:85vh}
}
