:root{--bg:#0b0f10;--panel:#0f1314;--muted:#9aa3a6;--accent:#e6e9e8;--accent-2:#9fb7b6;--gold:#D4AF37;--burgundy:#8B2635;--dark-bg:#0a0d0e}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial;color:var(--accent);background:var(--bg);-webkit-font-smoothing:antialiased}
.wrap{max-width:1100px;margin:0 auto;padding:2rem}
.topbar{border-bottom:1px solid rgba(255,255,255,0.03);background:var(--dark-bg)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between}
.brand-logo{display:inline-block;width:80px;height:auto;transition:opacity 0.2s ease}
.brand-logo img{width:100%;height:auto;max-width:80px;display:block}
.brand-logo svg{width:100%;height:auto;max-width:80px}
.brand-logo:hover{opacity:0.85}
.topnav a{color:var(--muted);text-decoration:none;margin-left:1rem;transition:color 0.2s ease}
.topnav a:hover{color:var(--gold)}
.small-btn{background:transparent;border:1px solid rgba(212,175,55,0.2);padding:.5rem .7rem;border-radius:8px;color:var(--accent);transition:all 0.2s ease}
.small-btn:hover{border-color:var(--gold);color:var(--gold)}

/* Brand banner with geometric accent */
.brand-banner{position:relative;padding:3.5rem 0;overflow:hidden;height: 400px; display: flex; align-items: center; justify-content: center; text-align: center; overflow-x: hidden;}
.banner-image { position:absolute;  overflow:visible; height: 100%; width: 100%;}
.banner-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;      /* fills container while preserving aspect ratio */
  object-position: center;/* centers the image */
  display: block;
}
.banner-content{position:relative;z-index:2;text-align:center}
.banner-title{font-family:'Playfair Display',serif;font-size:2.8rem;font-weight:700;margin:0 0 0.8rem;color:var(--accent);line-height:1.1}
.banner-title{color:var(--gold);text-shadow:0 2px 10px rgba(212,175,55,0.1)}
.banner-subtitle{color:var(--muted);font-size:1.05rem;margin:0}

/* Mobile nav toggle */
.nav-toggle{display:none;background:transparent;border:1px solid rgba(255,255,255,0.04);color:var(--accent);padding:.45rem .6rem;border-radius:8px;font-size:1.05rem}
.nav-toggle:focus{outline:2px solid rgba(212,175,55,0.3);outline-offset:2px}

/* Make the topnav collapse cleanly on small screens */
.topnav{display:flex;align-items:center}
.topnav.open{display:block}
.topnav a{display:inline-block}

.hero{position:relative}
.hero-inner{padding-top:3.5rem;padding-bottom:2rem;text-align:center}
.hero-copy h1{font-family:'Playfair Display',serif;font-size:48px;line-height:1.02;margin:0 0 .6rem;color:#e9efeef0}
.subtitle{color:var(--muted);max-width:720px;margin:0 auto 1rem}
.btn{display:inline-block;padding:.75rem 1.1rem;border-radius:999px;text-decoration:none;font-weight:600;transition:all 0.2s ease}
.btn-primary{background:var(--gold);color:#000;font-weight:700}
.btn-primary:hover{background:#E6C200;transform:translateY(-2px)}
.btn-outline{background:transparent;border:1px solid rgba(212,175,55,0.3);color:var(--accent);transition:all 0.2s ease}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);background:rgba(212,175,55,0.05)}
.hero-image{margin-top:1.25rem}
.hero-image img{width:100%;height:550px;object-fit:cover;border-radius:8px;display:block}

.section{padding:3rem 0}
.dark-section{background:linear-gradient(180deg, rgba(255,255,255,0.02), transparent);}
.muted{color:var(--muted)}

.split{display:grid;grid-template-columns:1fr 420px;gap:2rem;align-items:start}
.services-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}
.service h3{margin:0 0 .3rem}
.feature-card{background:rgba(212,175,55,0.05);padding:1.25rem;border-radius:12px;border-left:3px solid var(--gold)}
.feature-image img{width:100%;height:220px;object-fit:cover;border-radius:8px;margin-top:1rem}

.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.25rem}
.card{background:var(--panel);border-radius:10px;overflow:hidden;box-shadow:0 10px 30px rgba(2,6,23,0.6)}
.card-thumb{height:150px;background-size:cover;background-position:center}
.card-thumb{border:0;display:block;width:100%;cursor:pointer}
.thumb-a{background:linear-gradient(135deg,#fbe8e0,#f7d9d0)}
.thumb-b{background:linear-gradient(135deg,#e6f7f7,#d3f6f9)}
.thumb-c{background:linear-gradient(135deg,#eef2ff,#e6eaff)}
.card-body{padding:1rem}
.card-body h4{margin:0 0 .35rem}

/* .testimonial .video-box{width:100%;height:260px;background:linear-gradient(180deg,#0f1415,#0b0f10);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.video-box .play{font-size:2.5rem;opacity:.85}
blockquote{font-size:1.05rem;color:#e6efeef0;margin:0 0 .5rem}
cite{display:block;color:var(--muted);margin-bottom:1rem} */

.contact-wrap{display:grid;grid-template-columns:1fr 360px;gap:2rem;align-items:start}
form input, form textarea{width:100%;padding:.6rem;border-radius:8px;border:1px solid rgba(255,255,255,0.04);background:transparent;color:var(--accent);margin-bottom:.6rem}
.form-actions{display:flex;gap:.6rem}

.footer-inner{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 0;border-top:1px solid rgba(255,255,255,0.03)}

@media (max-width:980px){
  .split{grid-template-columns:1fr}
  .contact-wrap{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .nav-toggle{display:inline-block}
  .topnav{display:none;margin-top:0.75rem}
  .topnav.open{display:block;background:transparent;padding:0.5rem 0}
  .topnav a{display:block;padding:0.5rem 0;margin-left:0}
}
@media (max-width:680px){
  .hero-copy h1{font-size:32px}
  .topnav{display:none}
  .portfolio-grid{grid-template-columns:1fr}
}

/* Lightbox for portfolio */
.lightbox{position:fixed;inset:0;background:rgba(1,3,4,0.75);display:flex;align-items:center;justify-content:center;padding:2rem;z-index:120;opacity:0;pointer-events:none;transition:opacity .18s ease}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox .frame{max-width:1100px;width:100%;background:var(--panel);border-radius:10px;overflow:hidden}
.lightbox img{display:block;max-width:100%;height:auto}
.lightbox .meta{padding:1rem;color:var(--muted)}

/* Carousel styles for portfolio */
.portfolio-carousel{position:relative;margin-top:1rem}
.carousel-viewport{overflow:auto;white-space:nowrap;border-radius:10px}
.slides{display:flex;gap:0;margin:0;padding:0;list-style:none;transition:transform .45s ease}
.slide{min-width:100%;background:var(--panel);display:flex;flex-direction:column;align-items:stretch;overflow:hidden}
.slide img{max-width:500px;height:400px;object-fit:cover;display: block; margin: 10px; auto}
.slide-body{padding:1rem}
.carousel-controls{position:absolute;top:50%;left:0;right:0;display:flex;justify-content:space-between;transform:translateY(-50%);pointer-events:none}
.carousel-controls button{pointer-events:auto;background:rgba(0,0,0,0.5);border:0;color:var(--accent);width:44px;height:44px;border-radius:999px;margin:0 0.5rem;font-size:1.4rem}
.carousel-indicators{display:flex;gap:0.5rem;justify-content:center;margin-top:0.75rem}
.carousel-indicators button{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.12);border:none}
.carousel-indicators button[aria-selected="true"]{background:var(--gold)}

@media (max-width:980px){
  .slide img{height:220px}
}


/* Focus outlines for keyboard users */
button:focus, a:focus{outline:2px solid var(--gold);outline-offset:3px}
