/* ===== GUIDELAW IDE — Real Estate Law (Switzerland, Zürich) ===== */
/* Style: premium dark, emerald + bronze, marble, fixed left sidebar nav, horizontal gallery */

:root{
  --bg:#0e1311;
  --bg-2:#141b18;
  --panel:#1a2320;
  --emerald:#2f7d62;
  --emerald-l:#4caf8a;
  --bronze:#c1965a;
  --bronze-l:#dcb985;
  --cream:#f3efe7;
  --grey:#9aa5a0;
  --line:rgba(255,255,255,.08);
  --display:"Cormorant Garamond",Georgia,serif;
  --body:"Manrope",-apple-system,system-ui,sans-serif;
  --side:280px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--cream);background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* Layout: fixed sidebar + content */
.layout{display:flex;min-height:100vh}
.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--side);background:var(--bg-2);border-right:1px solid var(--line);padding:48px 40px;display:flex;flex-direction:column;z-index:100}
.sidebar .logo{font-family:var(--display);font-size:2rem;font-weight:600;letter-spacing:.5px;color:var(--cream);line-height:1}
.sidebar .logo b{color:var(--bronze);font-weight:600}
.sidebar .tagline{font-size:.74rem;letter-spacing:2px;text-transform:uppercase;color:var(--grey);margin-top:10px}
.side-nav{list-style:none;margin-top:64px;flex:1}
.side-nav li{margin-bottom:6px}
.side-nav a{display:block;font-size:.95rem;font-weight:600;color:var(--grey);padding:13px 16px;border-radius:8px;transition:.3s;position:relative}
.side-nav a::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:0;height:18px;background:var(--bronze);border-radius:2px;transition:.3s}
.side-nav a:hover,.side-nav a.active{color:var(--cream);background:var(--panel);padding-left:24px}
.side-nav a.active::before{width:3px}
.side-foot{font-size:.8rem;color:var(--grey);border-top:1px solid var(--line);padding-top:24px}
.side-foot a{color:var(--bronze-l)}
.side-cta{display:block;text-align:center;background:var(--bronze);color:var(--bg);font-weight:700;padding:13px;border-radius:8px;margin-bottom:22px;font-size:.9rem;transition:.3s}
.side-cta:hover{background:var(--bronze-l)}

.content{margin-left:var(--side);flex:1;width:calc(100% - var(--side))}
.inner{padding:0 64px}
.maxw{max-width:1000px}

/* Mobile top bar */
.mtop{display:none;position:sticky;top:0;z-index:100;background:var(--bg-2);border-bottom:1px solid var(--line);padding:16px 24px;align-items:center;justify-content:space-between}
.mtop .logo{font-family:var(--display);font-size:1.5rem;color:var(--cream)}
.mtop .logo b{color:var(--bronze)}
.burger{flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;display:flex}
.burger span{width:24px;height:2px;background:var(--cream)}

/* Hero */
.hero{min-height:96vh;display:flex;align-items:center;position:relative;overflow:hidden;padding:80px 64px}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.45}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,var(--bg) 25%,rgba(14,19,17,.5) 100%)}
.hero-in{position:relative;z-index:2;max-width:680px}
.hero-eyebrow{font-size:.76rem;letter-spacing:4px;text-transform:uppercase;color:var(--bronze);margin-bottom:26px;opacity:0;animation:fade .9s .2s forwards}
.hero h1{font-family:var(--display);font-size:clamp(3rem,6.5vw,5.6rem);font-weight:600;line-height:1;letter-spacing:-1px;margin-bottom:26px;opacity:0;animation:fade .9s .35s forwards}
.hero h1 em{font-style:italic;color:var(--bronze-l)}
.hero p{font-size:1.12rem;color:var(--grey);max-width:520px;margin-bottom:38px;opacity:0;animation:fade .9s .5s forwards}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fade .9s .65s forwards}
@keyframes fade{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}

.btn{display:inline-flex;align-items:center;gap:9px;font-size:.92rem;font-weight:700;padding:15px 32px;border-radius:8px;transition:.3s;cursor:pointer;border:none}
.btn-bronze{background:var(--bronze);color:var(--bg)}
.btn-bronze:hover{background:var(--bronze-l);transform:translateY(-2px)}
.btn-emerald{background:var(--emerald);color:var(--cream)}
.btn-emerald:hover{background:var(--emerald-l)}
.btn-line{background:transparent;color:var(--cream);border:1px solid var(--line)}
.btn-line:hover{border-color:var(--bronze);color:var(--bronze-l)}

.sec{padding:110px 0}
.eyebrow{font-size:.74rem;letter-spacing:3px;text-transform:uppercase;color:var(--bronze);font-weight:700;margin-bottom:16px}
.sec-title{font-family:var(--display);font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:600;letter-spacing:-.5px;line-height:1.05;color:var(--cream)}
.sec-sub{color:var(--grey);max-width:560px;margin-top:18px;font-size:1.05rem}

/* Numbered services list */
.svc-list{margin-top:60px;border-top:1px solid var(--line)}
.svc{display:grid;grid-template-columns:80px 1fr 2fr;gap:30px;padding:38px 0;border-bottom:1px solid var(--line);align-items:start;transition:.3s}
.svc:hover{background:var(--bg-2);padding-left:20px}
.svc .n{font-family:var(--display);font-size:1.6rem;color:var(--bronze)}
.svc h4{font-family:var(--display);font-size:1.7rem;color:var(--cream)}
.svc p{color:var(--grey);font-size:.96rem}

/* Horizontal gallery */
.gallery-head{padding:0 64px;margin-bottom:40px}
.hscroll{display:flex;gap:24px;overflow-x:auto;padding:0 64px 30px;scroll-snap-type:x mandatory}
.hscroll::-webkit-scrollbar{height:6px}
.hscroll::-webkit-scrollbar-thumb{background:var(--emerald);border-radius:3px}
.gcard{flex:0 0 420px;scroll-snap-align:start;border-radius:14px;overflow:hidden;position:relative;height:480px}
.gcard img{width:100%;height:100%;object-fit:cover;transition:.6s}
.gcard:hover img{transform:scale(1.05)}
.gcard .cap{position:absolute;left:0;right:0;bottom:0;padding:28px;background:linear-gradient(transparent,rgba(14,19,17,.95))}
.gcard .cap h4{font-family:var(--display);font-size:1.5rem;color:var(--cream)}
.gcard .cap p{font-size:.85rem;color:var(--bronze-l);letter-spacing:1px;text-transform:uppercase}

/* Feature split */
.fsplit{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:center;background:var(--bg-2);border-radius:18px;overflow:hidden}
.fsplit-img{height:100%;min-height:480px}
.fsplit-img img{width:100%;height:100%;object-fit:cover}
.fsplit-txt{padding:70px}
.fsplit-txt .check{list-style:none;margin-top:26px}
.fsplit-txt .check li{padding:13px 0;border-top:1px solid var(--line);display:flex;gap:13px;font-size:.97rem;color:var(--cream)}
.fsplit-txt .check li::before{content:"◆";color:var(--bronze);font-size:.7rem;margin-top:6px}

/* Stats */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.metric{background:var(--bg-2);padding:48px 30px;text-align:center}
.metric h3{font-family:var(--display);font-size:3rem;color:var(--bronze);font-weight:600}
.metric p{color:var(--grey);font-size:.88rem;margin-top:6px}

/* Quote */
.quote{max-width:820px}
.quote blockquote{font-family:var(--display);font-size:clamp(1.8rem,3.6vw,2.8rem);line-height:1.3;font-style:italic;color:var(--cream)}
.quote cite{display:block;margin-top:28px;font-style:normal;font-size:.82rem;letter-spacing:2px;text-transform:uppercase;color:var(--bronze)}

/* CTA */
.cta{background:linear-gradient(135deg,var(--emerald),var(--emerald-l));border-radius:18px;padding:80px 70px;text-align:center}
.cta .sec-title{color:var(--cream)}
.cta p{color:rgba(255,255,255,.9);max-width:520px;margin:16px auto 30px}

/* Footer */
.footer{border-top:1px solid var(--line);padding:64px 64px 40px;background:var(--bg-2)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:44px;padding-bottom:40px;border-bottom:1px solid var(--line)}
.footer .logo{font-family:var(--display);font-size:1.7rem;color:var(--cream);margin-bottom:14px}
.footer .logo b{color:var(--bronze)}
.footer h5{color:var(--cream);font-size:.78rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:18px}
.footer ul{list-style:none}
.footer li{margin-bottom:11px;font-size:.9rem;color:var(--grey)}
.footer a:hover{color:var(--bronze-l)}
.footer-bottom{padding-top:28px;display:flex;justify-content:space-between;font-size:.82rem;color:var(--grey);flex-wrap:wrap;gap:12px}

/* Page hero */
.phero{padding:130px 64px 70px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.phero .crumb{font-size:.78rem;letter-spacing:1px;color:var(--bronze);margin-bottom:20px}
.phero .crumb a:hover{color:var(--cream)}
.phero h1{font-family:var(--display);font-size:clamp(2.6rem,5.5vw,4.4rem);font-weight:600;color:var(--cream);letter-spacing:-.5px;margin-bottom:16px}
.phero p{color:var(--grey);max-width:560px}

/* About blocks */
.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.ab{background:var(--bg-2);padding:44px 36px}
.ab .n{font-family:var(--display);font-size:2rem;color:var(--bronze);margin-bottom:14px}
.ab h4{font-family:var(--display);font-size:1.4rem;color:var(--cream);margin-bottom:10px}
.ab p{color:var(--grey);font-size:.93rem}

/* Team */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.tm{background:var(--bg-2);border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.tm-img{height:320px;overflow:hidden}
.tm-img img{width:100%;height:100%;object-fit:cover;transition:.5s}
.tm:hover .tm-img img{transform:scale(1.04)}
.tm-info{padding:26px}
.tm-info h4{font-family:var(--display);font-size:1.35rem;color:var(--cream)}
.tm-info .role{color:var(--bronze);font-size:.8rem;letter-spacing:1px;text-transform:uppercase;margin:6px 0 10px}
.tm-info p{font-size:.88rem;color:var(--grey)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px}
.cblk{margin-bottom:30px;padding-bottom:30px;border-bottom:1px solid var(--line)}
.cblk .l{font-size:.74rem;letter-spacing:2px;text-transform:uppercase;color:var(--bronze);margin-bottom:8px}
.cblk .v{font-family:var(--display);font-size:1.3rem;color:var(--cream)}
.cform{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:46px}
.cform label{display:block;font-size:.78rem;letter-spacing:1px;text-transform:uppercase;color:var(--grey);margin:16px 0 8px}
.cform input,.cform textarea,.cform select{width:100%;padding:13px 15px;background:var(--bg);border:1px solid var(--line);border-radius:8px;color:var(--cream);font-family:inherit;font-size:.95rem;transition:.3s}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--bronze)}
.form-msg{margin-top:16px;padding:14px;background:rgba(47,125,98,.2);color:var(--emerald-l);border-radius:8px;display:none;font-size:.9rem;border:1px solid var(--emerald)}

/* Policy */
.policy{max-width:820px}
.policy h2{font-family:var(--display);font-size:1.9rem;color:var(--cream);margin:40px 0 14px}
.policy h3{font-size:1.05rem;color:var(--bronze-l);margin:26px 0 10px}
.policy p,.policy li{color:var(--grey);margin-bottom:13px;font-size:.97rem}
.policy ul{padding-left:22px}
.policy .updated{color:var(--bronze);font-size:.85rem;letter-spacing:1px}

/* Cookie */
.cookie{position:fixed;right:32px;bottom:32px;z-index:200;background:var(--panel);border:1px solid var(--line);padding:28px;border-radius:14px;max-width:380px;box-shadow:0 30px 70px -20px rgba(0,0,0,.6);transform:translateY(160%);transition:.5s cubic-bezier(.2,.8,.2,1)}
.cookie.show{transform:none}
.cookie h4{font-family:var(--display);font-size:1.4rem;color:var(--cream);margin-bottom:10px}
.cookie p{font-size:.88rem;color:var(--grey);margin-bottom:18px}
.cookie p a{color:var(--bronze-l);text-decoration:underline}
.cookie-btns{display:flex;gap:10px}
.cookie button{flex:1;padding:11px;border-radius:8px;font-size:.84rem;font-weight:700;cursor:pointer;border:none}
.ck-accept{background:var(--bronze);color:var(--bg)}
.ck-decline{background:transparent;color:var(--cream);border:1px solid var(--line)}

.reveal{opacity:0;transform:translateY(40px);transition:.9s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}

@media(max-width:980px){
  .sidebar{display:none}
  .mtop{display:flex}
  .content{margin-left:0;width:100%}
  .mnav{display:none;position:fixed;top:57px;left:0;right:0;background:var(--bg-2);border-bottom:1px solid var(--line);z-index:99;flex-direction:column;padding:18px 24px}
  .mnav.open{display:flex}
  .mnav a{padding:13px 0;color:var(--cream);font-weight:600;border-bottom:1px solid var(--line)}
  .hero,.inner,.phero,.footer,.gallery-head,.hscroll{padding-left:24px;padding-right:24px}
  .fsplit{grid-template-columns:1fr}.fsplit-img{min-height:300px}.fsplit-txt{padding:44px 28px}
  .metrics,.about-grid{grid-template-columns:1fr 1fr}
  .team{grid-template-columns:1fr}
  .svc{grid-template-columns:1fr;gap:8px}
  .footer-top{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .cta{padding:54px 28px}
  .gcard{flex-basis:300px;height:400px}
  .sec{padding:64px 0}
}
.mnav{display:none}
