/*
Theme Name:  PEC Panorama
Theme URI:   https://panorama-eng.net
Author:      Panorama Engineering Consultancy
Author URI:  https://panorama-eng.net
Description: Custom theme for Panorama Engineering Consultancy — a 100% Omani multi-disciplinary engineering consultancy established in 1984. Built with Playfair Display + Jost typography, animated particle hero, full mega-navigation, Studio/Projects/Sustainability sections.
Version:     3.0.0
License:     All Rights Reserved
Text Domain: pec-panorama
Tags:        custom-background, custom-logo, custom-menu, full-width-template, responsive-layout
*/

/* ══════════════════════════════════════
   RESET & ROOT
══════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --wine:#6f1d46;--wine-d:#3b132a;--wine-m:#8c3460;
  --navy:#00263e;--navy-m:#0e3a54;
  --copper:#b87954;--copper-l:#d4a07a;--copper-xl:#e8c4a0;
  --cream:#f7f3ef;--off:#faf8f5;--grey:#e8e4e0;--muted:#8a7f78;
  --dark:#1a0d12;--white:#fff;
  --ease:cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;font-weight:300;background:var(--off);color:var(--dark);overflow-x:hidden;cursor:none}

/* ── GRAIN OVERLAY ── */
body::before{content:'';position:fixed;inset:0;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='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:9997;opacity:.4}

/* ── CUSTOM CURSOR ── */
.cur{position:fixed;width:8px;height:8px;background:var(--copper);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .1s;mix-blend-mode:multiply}
.cur-r{position:fixed;width:32px;height:32px;border:1px solid var(--wine);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all .28s var(--ease);opacity:.65}
body:hover .cur-r{opacity:.65}

/* ══════════════════════════════════════
   NAVIGATION
══════════════════════════════════════ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;justify-content:space-between;align-items:center;
  padding:28px 64px;
  transition:all .5s var(--ease);
}
#nav.solid{background:rgba(59,19,42,.97);backdrop-filter:blur(20px);padding:16px 64px;border-bottom:1px solid rgba(255,255,255,.06)}
.nav-logo{display:flex;align-items:center;gap:13px;text-decoration:none;z-index:600}
.logo-mark{width:38px;height:38px;background:var(--copper);display:flex;align-items:center;justify-content:center;font-family:'Jost',sans-serif;font-size:12px;font-weight:600;color:var(--wine-d);letter-spacing:1px;flex-shrink:0}
.logo-words{display:flex;flex-direction:column;gap:1px}
.logo-main{font-size:14px;font-weight:500;color:#fff;letter-spacing:3px;text-transform:uppercase;line-height:1}
.logo-tag{font-size:7px;font-weight:400;color:var(--copper-l);letter-spacing:4px;text-transform:uppercase}

/* Desktop nav */
.nav-desk{display:flex;gap:0;list-style:none;align-items:stretch}
.nd-item{position:relative}
.nd-link{
  display:flex;align-items:center;gap:5px;padding:8px 16px;
  font-size:10px;letter-spacing:3px;text-transform:uppercase;font-weight:500;
  color:rgba(255,255,255,.72);text-decoration:none;cursor:none;
  transition:color .3s;white-space:nowrap
}
.nd-link:hover,.nd-link.act{color:#fff}
.nd-link svg{width:7px;height:5px;transition:transform .3s}
.nd-item:hover .nd-link svg{transform:rotate(180deg)}
.nd-cta{border:1px solid var(--copper) !important;color:var(--copper) !important;margin-left:8px}
.nd-cta:hover{background:var(--copper) !important;color:var(--wine-d) !important}

/* Dropdown */
.drop{
  position:absolute;top:calc(100% + 8px);left:0;
  background:rgba(44,10,30,.97);backdrop-filter:blur(20px);
  border-top:2px solid var(--copper);min-width:230px;
  opacity:0;visibility:hidden;transform:translateY(10px);
  transition:all .3s var(--ease);box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.nd-item:hover .drop{opacity:1;visibility:visible;transform:translateY(0)}
.drop a{
  display:flex;align-items:center;gap:10px;padding:13px 22px;
  font-size:10px;letter-spacing:3px;text-transform:uppercase;font-weight:500;
  color:rgba(255,255,255,.55);text-decoration:none;cursor:none;
  border-bottom:1px solid rgba(255,255,255,.04);transition:all .2s
}
.drop a:hover{color:#fff;background:rgba(184,121,84,.1);padding-left:28px}
.drop-dot{width:4px;height:4px;border-radius:50%;background:var(--copper);opacity:0;transition:opacity .2s;flex-shrink:0}
.drop a:hover .drop-dot{opacity:1}
.has-sub{position:relative}
.has-sub>.drop-row{display:flex;justify-content:space-between;align-items:center}
.has-sub>.drop-row::after{content:'›';color:var(--copper);font-size:13px}
.sub-drop{position:absolute;left:100%;top:0;background:rgba(0,38,62,.97);backdrop-filter:blur(20px);border-top:2px solid var(--copper);min-width:210px;opacity:0;visibility:hidden;transform:translateX(8px);transition:all .3s var(--ease)}
.has-sub:hover .sub-drop{opacity:1;visibility:visible;transform:translateX(0)}

/* Hamburger */
.burger{display:none;flex-direction:column;gap:5px;cursor:none;z-index:600;padding:4px}
.burger span{display:block;width:26px;height:1.5px;background:#fff;transition:all .4s var(--ease);transform-origin:center}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile overlay */
#mob-menu{
  position:fixed;inset:0;z-index:450;
  background:linear-gradient(140deg,var(--wine-d) 0%,var(--wine) 50%,var(--navy) 100%);
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s;
}
#mob-menu.open{opacity:1;visibility:visible}
.mob-items{list-style:none;text-align:center;display:flex;flex-direction:column;gap:8px}
.mob-item a{
  font-family:'Playfair Display',serif;font-size:clamp(28px,6vw,52px);
  font-weight:400;color:rgba(255,255,255,.85);text-decoration:none;
  letter-spacing:2px;display:block;padding:6px 0;
  transform:translateY(20px);opacity:0;transition:all .4s var(--ease),color .3s;
}
#mob-menu.open .mob-item a{transform:translateY(0);opacity:1}
.mob-item:nth-child(1) a{transition-delay:.1s}
.mob-item:nth-child(2) a{transition-delay:.15s}
.mob-item:nth-child(3) a{transition-delay:.2s}
.mob-item:nth-child(4) a{transition-delay:.25s}
.mob-item:nth-child(5) a{transition-delay:.3s}
.mob-item:nth-child(6) a{transition-delay:.35s}
.mob-item a:hover{color:var(--copper-l)}
.mob-contact{margin-top:40px;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.35);transform:translateY(20px);opacity:0;transition:all .4s .4s var(--ease)}
#mob-menu.open .mob-contact{transform:translateY(0);opacity:1}

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero{min-height:100vh;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end}
#hero-canvas{position:absolute;inset:0;z-index:0}
.hero-grad{position:absolute;inset:0;background:linear-gradient(140deg,rgba(59,19,42,.95) 0%,rgba(111,29,70,.85) 45%,rgba(0,38,62,.9) 100%);z-index:1}
.hero-vline{position:absolute;top:0;bottom:0;right:28%;width:1px;background:linear-gradient(180deg,transparent,rgba(184,121,84,.25) 20%,rgba(184,121,84,.25) 80%,transparent);z-index:2}
.hero-body{position:relative;z-index:3;padding:0 64px 88px;display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:flex-end}
.h-eye{font-size:9.5px;letter-spacing:7px;text-transform:uppercase;font-weight:500;color:var(--copper-l);margin-bottom:24px;display:flex;align-items:center;gap:14px;opacity:0;animation:up .9s .2s forwards}
.h-eye::before{content:'';width:40px;height:1px;background:var(--copper)}
.h-h1{font-family:'Playfair Display',serif;font-size:clamp(52px,7.5vw,108px);font-weight:400;line-height:.95;color:#fff;letter-spacing:-2px;opacity:0;animation:up 1.1s .35s forwards}
.h-h1 em{font-style:italic;color:var(--copper-l);display:block}
.h-sub{font-size:15px;font-weight:300;line-height:1.8;color:rgba(255,255,255,.55);max-width:460px;margin-top:30px;opacity:0;animation:up .9s .6s forwards}
.h-btns{display:flex;gap:14px;margin-top:36px;opacity:0;animation:up .9s .75s forwards}
.h-btn-p{display:inline-flex;align-items:center;gap:10px;padding:14px 36px;background:var(--copper);color:var(--wine-d);font-size:10px;letter-spacing:4px;text-transform:uppercase;font-weight:600;text-decoration:none;cursor:none;transition:all .3s}
.h-btn-p:hover{background:var(--copper-l);transform:translateY(-2px)}
.h-btn-s{display:inline-flex;align-items:center;gap:10px;padding:14px 36px;border:1px solid rgba(255,255,255,.3);color:rgba(255,255,255,.8);font-size:10px;letter-spacing:4px;text-transform:uppercase;font-weight:500;text-decoration:none;cursor:none;transition:all .3s}
.h-btn-s:hover{border-color:rgba(255,255,255,.7);color:#fff}
.h-right{display:flex;flex-direction:column;gap:24px;opacity:0;animation:up 1s .7s forwards}
.h-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.06)}
.h-stat{background:rgba(44,10,30,.6);backdrop-filter:blur(12px);padding:28px 22px;position:relative;overflow:hidden}
.h-stat::before{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--copper),transparent);transform:scaleX(0);transition:transform .4s var(--ease)}
.h-stat:hover::before{transform:scaleX(1)}
.h-num{font-family:'Playfair Display',serif;font-size:52px;font-weight:400;color:var(--copper-l);line-height:1;display:block;letter-spacing:-2px}
.h-lbl{font-size:8px;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:4px;display:block}
.h-quote{border-left:2px solid var(--copper);padding:0 0 0 20px}
.h-quote p{font-size:13px;line-height:1.8;color:rgba(255,255,255,.55);font-style:italic}
.h-quote cite{display:block;margin-top:10px;font-size:8.5px;letter-spacing:3px;text-transform:uppercase;color:var(--copper-l);font-style:normal;font-weight:500}
.h-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:3;opacity:0;animation:fadeIn 1s 1.4s forwards}
.h-scroll span{font-size:7.5px;letter-spacing:5px;color:rgba(255,255,255,.3);text-transform:uppercase}
.scroll-line{width:1px;height:50px;background:linear-gradient(var(--copper),transparent);animation:scr 2.2s infinite}

/* ══════════════════════════════════════
   MARQUEE
══════════════════════════════════════ */
.marq{background:var(--navy);padding:14px 0;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.04)}
.marq-t{display:flex;animation:marquee 34s linear infinite;white-space:nowrap}
.mi{font-size:9.5px;letter-spacing:5px;text-transform:uppercase;color:rgba(255,255,255,.32);padding:0 32px;flex-shrink:0;font-weight:400}
.md{color:var(--copper);font-size:7px;flex-shrink:0;display:flex;align-items:center}

/* ══════════════════════════════════════
   SECTION HELPERS
══════════════════════════════════════ */
.sec{padding:120px 64px}
.sec-lbl{font-size:8.5px;letter-spacing:6px;text-transform:uppercase;font-weight:500;color:var(--copper);margin-bottom:14px;display:flex;align-items:center;gap:12px}
.sec-lbl::before{content:'';width:26px;height:1px;background:var(--copper)}
.sec-lbl.cen{justify-content:center}
.sec-lbl.cen::before,.sec-lbl.lt::before{background:var(--copper-l)}
.sec-lbl.lt{color:var(--copper-l)}
.sec-h{font-family:'Playfair Display',serif;font-size:clamp(36px,4.5vw,62px);font-weight:400;line-height:1.05;color:var(--wine-d);letter-spacing:-.5px}
.sec-h em{font-style:italic;color:var(--wine)}
.sec-h.lt{color:#fff}
.sec-h.lt em{color:var(--copper-l)}

/* ══════════════════════════════════════
   PHILOSOPHY
══════════════════════════════════════ */
.philo{background:var(--wine);padding:80px 64px;display:flex;gap:80px;align-items:center}
.philo-q{font-family:'Playfair Display',serif;font-size:clamp(44px,5.5vw,76px);font-weight:400;color:#fff;line-height:1;letter-spacing:-.5px;flex:1}
.philo-q em{font-style:italic;color:var(--copper-l);display:block}
.philo-r{flex:0 0 360px;font-size:14.5px;line-height:1.85;color:rgba(255,255,255,.6);border-left:1px solid var(--copper);padding-left:24px}

/* ══════════════════════════════════════
   STUDIO
══════════════════════════════════════ */
.studio{padding:120px 0;background:var(--off)}
.studio-head{padding:0 64px 40px;display:flex;justify-content:space-between;align-items:flex-end}
.s-tab-bar{display:flex;padding:0 64px;border-bottom:1px solid var(--grey);position:relative}
.s-tab{padding:16px 26px;font-size:10px;letter-spacing:4px;text-transform:uppercase;font-weight:500;color:var(--muted);cursor:none;border-bottom:2px solid transparent;transition:all .3s;margin-bottom:-1px;user-select:none}
.s-tab:hover{color:var(--wine)}
.s-tab.on{color:var(--wine);border-bottom-color:var(--wine)}
.s-pane{display:none;padding:64px}
.s-pane.on{display:block}

/* About pane */
.ab-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.ab-img{position:relative}
.ab-box{height:520px;background:linear-gradient(135deg,var(--wine-d),var(--wine));display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.ab-box::before{content:'';position:absolute;inset:22px;border:1px solid rgba(184,121,84,.18)}
.ab-box::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 30%,rgba(184,121,84,.08),transparent 60%)}
.ab-box-inner{text-align:center;position:relative;z-index:1}
.ab-yr{font-family:'Playfair Display',serif;font-size:110px;font-weight:400;color:var(--copper-l);line-height:1;display:block;letter-spacing:-4px}
.ab-yr-lbl{font-size:9px;letter-spacing:5px;text-transform:uppercase;color:rgba(255,255,255,.45)}
.ab-badge{position:absolute;bottom:-22px;right:-22px;width:165px;height:150px;background:var(--copper);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}
.ab-badge .bn{font-family:'Playfair Display',serif;font-size:52px;font-weight:400;color:var(--wine-d);line-height:1}
.ab-badge .bl{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--wine-d);font-weight:500;text-align:center}
.ab-body{font-size:15px;line-height:1.85;color:#4a3540;margin:24px 0}
.ab-certs{border-top:1px solid var(--grey)}
.ab-cert{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--grey);font-size:12.5px;color:var(--muted);cursor:none;transition:color .3s}
.ab-cert:hover{color:var(--wine)}
.ck{color:var(--copper)}

/* Team pane */
.team-g{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.tm{position:relative;overflow:hidden;cursor:none}
.tm-img{height:360px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.tm-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(44,10,30,.95) 100%)}
.tm-over{position:absolute;inset:0;background:var(--wine);display:flex;flex-direction:column;justify-content:center;padding:28px;opacity:0;transform:translateY(10px);transition:all .4s var(--ease);z-index:3}
.tm:hover .tm-over{opacity:1;transform:translateY(0)}
.tm-over p{font-size:12.5px;line-height:1.7;color:rgba(255,255,255,.75)}
.ti{position:absolute;bottom:0;left:0;right:0;padding:20px;z-index:2}
.t-name{font-family:'Playfair Display',serif;font-size:20px;font-weight:400;color:#fff;margin-bottom:3px}
.t-role{font-size:8.5px;letter-spacing:3px;text-transform:uppercase;color:var(--copper-l);font-weight:500}
.tc1{background:linear-gradient(135deg,#3b132a,#6f1d46)}
.tc2{background:linear-gradient(135deg,#00263e,#0e3a54)}
.tc3{background:linear-gradient(135deg,#2a1506,#5a3515)}
.tc4{background:linear-gradient(135deg,#1a0a28,#3a1a55)}

/* Services pane */
.sv-bar{display:flex;border-bottom:1px solid var(--grey);margin-bottom:0;flex-wrap:wrap}
.sv-t{padding:12px 20px;font-size:9.5px;letter-spacing:3px;text-transform:uppercase;font-weight:500;color:var(--muted);cursor:none;border-bottom:2px solid transparent;transition:all .3s;margin-bottom:-1px}
.sv-t:hover{color:var(--wine)}
.sv-t.on{color:var(--wine);border-bottom-color:var(--copper)}
.sv-pane{display:none;padding-top:48px}
.sv-pane.on{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.sv-block h3{font-family:'Playfair Display',serif;font-size:clamp(30px,3.5vw,50px);font-weight:400;color:var(--wine-d);line-height:1.1;margin-bottom:20px}
.sv-block p{font-size:14px;line-height:1.85;color:var(--muted);margin-bottom:14px}
.sv-ul{list-style:none;display:flex;flex-direction:column;gap:9px;margin-top:20px}
.sv-ul li{font-size:13px;color:var(--muted);padding-left:20px;position:relative}
.sv-ul li::before{content:'—';position:absolute;left:0;color:var(--copper)}
.sv-vis{height:400px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;border:1px solid var(--grey)}
.sv-vis::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(111,29,70,.04),rgba(0,38,62,.04))}

/* ══════════════════════════════════════
   PROJECTS
══════════════════════════════════════ */
.proj-sec{padding:120px 0;background:var(--navy)}
.proj-head{padding:0 64px;display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px}
.cat-bar{display:flex;padding:0 64px;border-bottom:1px solid rgba(255,255,255,.07);overflow-x:auto;scrollbar-width:none}
.cat-bar::-webkit-scrollbar{display:none}
.ct{padding:13px 22px;font-size:9.5px;letter-spacing:3px;text-transform:uppercase;font-weight:500;color:rgba(255,255,255,.38);cursor:none;border-bottom:2px solid transparent;transition:all .3s;margin-bottom:-1px;flex-shrink:0}
.ct:hover{color:rgba(255,255,255,.75)}
.ct.on{color:var(--copper-l);border-bottom-color:var(--copper)}
.p-grid{display:none;grid-template-columns:repeat(3,1fr);gap:2px;padding:48px 64px 0}
.p-grid.on{display:grid}
.p-grid.on .pc:nth-child(1){grid-column:span 2}
.p-grid.on .pc:nth-child(4){grid-column:span 2;grid-column-start:2}
.pc{position:relative;overflow:hidden;cursor:none}
.p-img{position:relative;overflow:hidden}
.p-img-bg{width:100%;transition:transform .7s var(--ease)}
.p-img-bg.tall{height:560px;display:flex;align-items:center;justify-content:center}
.p-img-bg.short{height:380px;display:flex;align-items:center;justify-content:center}
.pc:hover .p-img-bg{transform:scale(1.06)}
.p-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,38,62,.92) 100%);transition:opacity .4s}
.p-hover-overlay{position:absolute;inset:0;background:rgba(111,29,70,.82);opacity:0;transition:opacity .4s var(--ease);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px}
.pc:hover .p-hover-overlay{opacity:1}
.pho-title{font-family:'Playfair Display',serif;font-size:28px;font-weight:400;color:#fff;text-align:center;margin-bottom:14px}
.pho-desc{font-size:13px;line-height:1.7;color:rgba(255,255,255,.75);text-align:center;margin-bottom:24px}
.pho-link{font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--copper-l);font-weight:500;border-bottom:1px solid rgba(184,121,84,.4);padding-bottom:3px}
.p-tag{position:absolute;top:18px;left:18px;background:var(--copper);color:var(--wine-d);font-size:7.5px;letter-spacing:3px;text-transform:uppercase;font-weight:600;padding:5px 11px;z-index:3}
.p-info{padding:18px 0 0}
.p-name{font-family:'Playfair Display',serif;font-size:22px;font-weight:400;color:#fff;line-height:1.2;margin-bottom:4px}
.p-loc{font-size:10px;letter-spacing:2px;color:rgba(255,255,255,.35);text-transform:uppercase}
.p-meta{display:flex;gap:20px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.06)}
.pm{font-size:11px;color:rgba(255,255,255,.3)}
.pm strong{display:block;font-size:12px;color:var(--copper-l);font-weight:400;margin-bottom:1px}
.view-all-link{display:inline-flex;align-items:center;gap:9px;font-size:9.5px;letter-spacing:4px;text-transform:uppercase;font-weight:500;color:var(--copper-l);text-decoration:none;border-bottom:1px solid rgba(184,121,84,.3);padding-bottom:2px;transition:border-color .3s;cursor:none}
.view-all-link:hover{border-color:var(--copper-l)}
.view-all-link::after{content:'→';font-size:14px}

/* Project background colours */
.bg1{background:linear-gradient(135deg,#1e3a4a,#2d5468)}
.bg2{background:linear-gradient(135deg,#3b1328,#5c2040)}
.bg3{background:linear-gradient(135deg,#1a2f1a,#2d4a2d)}
.bg4{background:linear-gradient(135deg,#2a2015,#453520)}
.bg5{background:linear-gradient(135deg,#1a1a3a,#2d2d5a)}
.bg6{background:linear-gradient(135deg,#1a2a2a,#2d4545)}
.bg7{background:linear-gradient(135deg,#2a1520,#452030)}
.bg8{background:linear-gradient(135deg,#1f1f10,#3a3a1a)}
.bg9{background:linear-gradient(135deg,#0e1e2a,#1a3040)}

/* ══════════════════════════════════════
   AWARDS
══════════════════════════════════════ */
.awards-sec{padding:120px 64px;background:var(--wine-d)}
.awards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.06);margin-top:72px}
.aw-card{background:var(--wine-d);padding:48px 32px;position:relative;overflow:hidden;cursor:none;transition:background .35s}
.aw-card:hover{background:rgba(111,29,70,.5)}
.aw-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--copper);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.aw-card:hover::after{transform:scaleX(1)}
.aw-yr{font-family:'Playfair Display',serif;font-size:80px;font-weight:400;color:rgba(184,121,84,.08);position:absolute;top:10px;right:16px;line-height:1;transition:color .35s}
.aw-card:hover .aw-yr{color:rgba(184,121,84,.14)}
.aw-icon{font-size:28px;margin-bottom:22px;display:block}
.aw-body h4{font-size:16px;font-weight:500;color:#fff;margin-bottom:8px;line-height:1.25}
.aw-body p{font-size:12px;line-height:1.65;color:rgba(255,255,255,.45)}
.aw-body .aw-tag{display:inline-block;margin-top:14px;font-size:8px;letter-spacing:3px;text-transform:uppercase;font-weight:500;color:var(--copper-l);border:1px solid rgba(184,121,84,.25);padding:4px 10px}

/* ══════════════════════════════════════
   SUSTAINABILITY
══════════════════════════════════════ */
.sust{padding:120px 64px;background:var(--off)}
.sust-intro{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-bottom:80px}
.sust-intro p{font-size:15px;line-height:1.85;color:var(--muted)}
.sust-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:64px}
.sp-card{border:1px solid var(--grey);padding:36px 28px;position:relative;overflow:hidden;transition:border-color .35s,transform .3s;cursor:none}
.sp-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--wine);transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease)}
.sp-card:hover{border-color:rgba(111,29,70,.25);transform:translateY(-4px)}
.sp-card:hover::before{transform:scaleY(1)}
.sp-num{font-family:'Playfair Display',serif;font-size:72px;font-weight:400;color:rgba(111,29,70,.06);position:absolute;top:-10px;right:12px;line-height:1}
.sp-icon{font-size:26px;margin-bottom:18px;display:block}
.sp-name{font-size:18px;font-weight:500;color:var(--wine-d);margin-bottom:10px}
.sp-desc{font-size:13px;line-height:1.7;color:var(--muted)}
.sp-bar-wrap{margin-top:18px}
.sp-bar-lbl{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--copper);margin-bottom:8px;display:flex;justify-content:space-between}
.sp-bar{height:3px;background:var(--grey);border-radius:2px;overflow:hidden}
.sp-bar-fill{height:100%;background:linear-gradient(90deg,var(--wine),var(--copper));border-radius:2px;width:0;transition:width 1.5s var(--ease)}
.sust-tbl{width:100%;border-collapse:collapse}
.sust-tbl th{background:var(--wine);color:var(--copper-l);font-size:8.5px;letter-spacing:5px;text-transform:uppercase;font-weight:500;padding:18px 22px;text-align:left;border-bottom:2px solid var(--copper)}
.sust-tbl td{padding:16px 22px;font-size:13px;color:var(--muted);font-weight:300;line-height:1.5;border-bottom:1px solid var(--grey);vertical-align:top}
.sust-tbl tr:hover td{background:rgba(111,29,70,.03);color:var(--dark)}
.sust-tbl td:first-child{font-weight:500;color:var(--wine-d);font-size:13px}
.s-pill{display:inline-block;padding:3px 10px;background:rgba(111,29,70,.08);color:var(--wine);font-size:8px;letter-spacing:2px;text-transform:uppercase;font-weight:500;border:1px solid rgba(111,29,70,.18)}

/* ══════════════════════════════════════
   NEWS
══════════════════════════════════════ */
.news-sec{padding:120px 64px;background:var(--cream)}
.news-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px;margin-top:56px}
.nw-card{cursor:none;overflow:hidden;background:#fff;border:1px solid var(--grey);transition:transform .3s var(--ease),box-shadow .3s}
.nw-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(111,29,70,.1)}
.nw-img{height:240px;overflow:hidden;position:relative}
.nw-img-bg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:transform .6s var(--ease)}
.nw-card:hover .nw-img-bg{transform:scale(1.06)}
.nw-body{padding:28px 26px}
.nw-tag{font-size:8px;letter-spacing:4px;text-transform:uppercase;font-weight:600;color:var(--copper);margin-bottom:12px;display:block}
.nw-title{font-family:'Playfair Display',serif;font-size:20px;font-weight:400;color:var(--wine-d);line-height:1.3;margin-bottom:12px}
.nw-card:first-child .nw-title{font-size:26px}
.nw-excerpt{font-size:13px;line-height:1.7;color:var(--muted)}
.nw-foot{display:flex;justify-content:space-between;align-items:center;padding:16px 26px;border-top:1px solid var(--grey);margin-top:4px}
.nw-date{font-size:10px;color:var(--muted);letter-spacing:1px}
.nw-read{font-size:9.5px;letter-spacing:3px;text-transform:uppercase;color:var(--wine);font-weight:500}

/* ══════════════════════════════════════
   INSTAGRAM
══════════════════════════════════════ */
.insta-sec{padding:120px 64px;background:var(--off)}
.insta-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px}
.ig-follow{display:inline-flex;align-items:center;gap:9px;font-size:9.5px;letter-spacing:4px;text-transform:uppercase;font-weight:500;color:var(--wine);text-decoration:none;border-bottom:1px solid rgba(111,29,70,.25);padding-bottom:2px;transition:border-color .3s}
.ig-follow:hover{border-color:var(--wine)}
.ig-follow::before{content:'@';color:var(--copper)}
.ig-big{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3px;margin-bottom:3px}
.ig-plaque{position:relative;overflow:hidden;cursor:none}
.ig-plaque-bg{width:100%;transition:transform .7s var(--ease)}
.ig-plaque:hover .ig-plaque-bg{transform:scale(1.04)}
.ig-plaque-bg.tall{height:500px;display:flex;align-items:center;justify-content:center}
.ig-plaque-bg.short{height:248px;display:flex;align-items:center;justify-content:center}
.ig-ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(44,10,30,.1) 0%,rgba(44,10,30,.75) 100%)}
.ig-content{position:absolute;bottom:0;left:0;right:0;padding:24px;z-index:2}
.ig-cat{font-size:8px;letter-spacing:4px;text-transform:uppercase;color:var(--copper-l);font-weight:500;display:block;margin-bottom:7px}
.ig-cap{font-size:13.5px;font-weight:300;color:#fff;line-height:1.5}
.ig-lk{margin-top:8px;font-size:9.5px;color:rgba(255,255,255,.45);letter-spacing:1px}
.ig-row{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}
.ig-mini{position:relative;overflow:hidden;cursor:none}
.ig-mini-bg{height:200px;display:flex;align-items:center;justify-content:center;transition:transform .6s var(--ease)}
.ig-mini:hover .ig-mini-bg{transform:scale(1.06)}
.ig-mini-ov{position:absolute;inset:0;background:linear-gradient(180deg,transparent 20%,rgba(44,10,30,.85) 100%)}
.ig-mini-info{position:absolute;bottom:0;left:0;right:0;padding:16px;z-index:2}
.ig-mini-info span{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--copper-l);display:block;margin-bottom:4px}
.ig-mini-info p{font-size:12px;color:#fff;line-height:1.4}

/* ══════════════════════════════════════
   VALUES
══════════════════════════════════════ */
.vals{padding:110px 64px;background:var(--wine-d)}
.vals-g{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:rgba(255,255,255,.05);margin-top:64px}
.vc{background:var(--wine-d);padding:44px 26px;text-align:center;border-bottom:3px solid transparent;transition:all .35s;cursor:none}
.vc:hover{border-bottom-color:var(--copper);background:rgba(111,29,70,.5)}
.v-ic{width:46px;height:46px;border-radius:50%;border:1px solid rgba(184,121,84,.22);display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:17px;transition:border-color .3s}
.vc:hover .v-ic{border-color:var(--copper)}
.v-name{font-size:15px;font-weight:500;color:#fff;margin-bottom:9px}
.v-desc{font-size:12px;line-height:1.65;color:rgba(255,255,255,.4)}

/* ══════════════════════════════════════
   FOUNDER QUOTE
══════════════════════════════════════ */
.founder{background:var(--cream);padding:100px 64px;display:grid;grid-template-columns:2fr 1fr;gap:80px;align-items:center}
.fq-mark{font-family:'Playfair Display',serif;font-size:180px;font-weight:400;color:rgba(111,29,70,.07);line-height:.8;display:block}
.fq-text{font-family:'Playfair Display',serif;font-size:clamp(20px,2.5vw,32px);font-weight:400;font-style:italic;line-height:1.6;color:var(--wine-d);margin-top:-20px}
.fq-cite{margin-top:30px;display:flex;align-items:center;gap:14px}
.fq-line{width:30px;height:1px;background:var(--copper)}
.fq-name{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--copper);font-weight:500}
.f-info{padding:40px 34px;background:var(--wine);position:relative}
.f-info::before{content:'';position:absolute;inset:14px;border:1px solid rgba(255,255,255,.09)}
.f-info h3{font-family:'Playfair Display',serif;font-size:26px;font-weight:400;color:#fff;margin-bottom:7px}
.f-info h4{font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--copper-l);font-weight:500;margin-bottom:18px}
.f-info p{font-size:13px;line-height:1.75;color:rgba(255,255,255,.6)}

/* ══════════════════════════════════════
   ISO BAND
══════════════════════════════════════ */
.iso{background:var(--navy);padding:60px 64px;display:flex;align-items:center;gap:52px;justify-content:space-between}
.iso-b{flex-shrink:0;width:108px;height:108px;border:2px solid var(--copper);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px}
.iso-b span{font-size:13px;font-weight:500;color:var(--copper);letter-spacing:1px}
.iso-b small{font-size:10px;color:rgba(255,255,255,.4)}
.iso-t h3{font-family:'Playfair Display',serif;font-size:24px;font-weight:400;color:#fff;margin-bottom:8px}
.iso-t p{font-size:13px;line-height:1.7;color:rgba(255,255,255,.5);max-width:580px}
.iso-v{text-align:right;flex-shrink:0}
.iso-v span{font-size:8px;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.28);display:block;margin-bottom:6px}
.iso-v strong{font-size:18px;font-weight:300;color:var(--copper-l);letter-spacing:2px}

/* ══════════════════════════════════════
   CONTACT
══════════════════════════════════════ */
.contact{background:linear-gradient(140deg,var(--wine-d) 0%,var(--wine) 55%,var(--navy) 100%);padding:140px 64px;text-align:center;position:relative;overflow:hidden}
.contact::before,.contact::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%}
.contact::before{width:680px;height:680px;border:1px solid rgba(184,121,84,.08)}
.contact::after{width:440px;height:440px;border:1px solid rgba(184,121,84,.06)}
.con-in{position:relative;z-index:2}
.con-h{font-family:'Playfair Display',serif;font-size:clamp(46px,7vw,90px);font-weight:400;color:#fff;line-height:.98;margin:20px auto 52px;letter-spacing:-2px;max-width:780px}
.con-h em{font-style:italic;color:var(--copper-l)}
.con-btn{display:inline-flex;align-items:center;gap:12px;background:var(--copper);color:var(--wine-d);padding:17px 50px;font-size:10.5px;letter-spacing:5px;text-transform:uppercase;font-weight:600;text-decoration:none;cursor:none;transition:all .3s}
.con-btn:hover{background:var(--copper-l);transform:translateY(-2px);box-shadow:0 16px 40px rgba(0,0,0,.3)}
.con-row{display:flex;justify-content:center;gap:0;margin-top:72px;padding-top:56px;border-top:1px solid rgba(255,255,255,.08)}
.cd{flex:1;max-width:240px;text-align:center;padding:0 28px;border-right:1px solid rgba(255,255,255,.06)}
.cd:last-child{border-right:none}
.cd-l{font-size:7.5px;letter-spacing:5px;text-transform:uppercase;color:var(--copper-l);font-weight:500;display:block;margin-bottom:9px}
.cd-v{font-size:14px;color:rgba(255,255,255,.75);font-weight:300;line-height:1.5}

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
footer{background:var(--wine-d);border-top:1px solid rgba(255,255,255,.04);padding:56px 64px 36px}
.ft{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.05);margin-bottom:28px}
.fb{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.fb-m{width:34px;height:34px;background:var(--copper);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--wine-d)}
.fb-n{font-size:12px;font-weight:500;color:#fff;letter-spacing:3px;text-transform:uppercase}
.f-desc{font-size:12px;line-height:1.7;color:rgba(255,255,255,.28)}
.fc h4{font-size:8px;letter-spacing:5px;text-transform:uppercase;color:var(--copper-l);font-weight:500;margin-bottom:18px}
.fc ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.fc ul a{font-size:12px;color:rgba(255,255,255,.32);text-decoration:none;letter-spacing:.3px;transition:color .3s;cursor:none}
.fc ul a:hover{color:rgba(255,255,255,.8)}
.fb2{display:flex;justify-content:space-between;align-items:center}
.f-copy{font-size:10px;color:rgba(255,255,255,.18);letter-spacing:1px}
.f-soc{display:flex;gap:16px}
.f-soc a{font-size:9.5px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.28);text-decoration:none;cursor:none;transition:color .3s}
.f-soc a:hover{color:var(--copper-l)}

/* ══════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════ */
@keyframes up{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes scr{0%,100%{opacity:.25;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}
.rev{opacity:0;transform:translateY(32px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
.rev.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:1100px){
  .hero-body,.sust-intro,.ab-grid,.founder,.con-row{grid-template-columns:1fr}
  .h-right{margin-top:40px}
  .awards-grid{grid-template-columns:repeat(2,1fr)}
  .team-g{grid-template-columns:repeat(2,1fr)}
  .news-grid{grid-template-columns:1fr 1fr}
  .p-grid.on .pc:nth-child(1),.p-grid.on .pc:nth-child(4){grid-column:span 1}
  .ig-big{grid-template-columns:1fr 1fr}
  .ig-big .ig-plaque:first-child .ig-plaque-bg.tall{height:380px}
  .ig-row{grid-template-columns:repeat(2,1fr)}
  .ft{grid-template-columns:1fr 1fr}
  .vals-g{grid-template-columns:repeat(3,1fr)}
  .sust-pillars{grid-template-columns:1fr 1fr}
  .philo{flex-direction:column;gap:40px}
  .philo-r{flex:none}
  #nav{padding:22px 32px}
  #nav.solid{padding:14px 32px}
  .sec{padding:80px 32px}
  .studio-head,.proj-head,.insta-head{padding:0 32px}
  .s-tab-bar,.cat-bar{padding:0 32px}
  .s-pane,.p-grid,.ig-big,.ig-row{padding-left:32px;padding-right:32px}
  .p-grid{padding:48px 32px 0}
}
@media(max-width:768px){
  .nav-desk{display:none}
  .burger{display:flex}
  .hero-body{padding:0 24px 80px;grid-template-columns:1fr}
  .h-stats{grid-template-columns:1fr 1fr}
  .h-num{font-size:38px}
  .p-grid.on{grid-template-columns:1fr}
  .p-grid{padding:32px 24px 0}
  .awards-grid,.sust-pillars,.vals-g{grid-template-columns:1fr 1fr}
  .team-g{grid-template-columns:1fr}
  .news-grid{grid-template-columns:1fr}
  .ig-big{grid-template-columns:1fr}
  .ig-row{grid-template-columns:1fr 1fr}
  .sec{padding:72px 24px}
  .studio-head,.proj-head,.insta-head,.sust,.founder,.awards-sec,.news-sec{padding-left:24px;padding-right:24px}
  .s-tab-bar,.cat-bar{padding:0 24px}
  .s-pane{padding:40px 24px}
  .philo{padding:60px 24px}
  #nav{padding:20px 24px}
  #nav.solid{padding:14px 24px}
  .ft{grid-template-columns:1fr}
  footer{padding:48px 24px 28px}
  .sv-pane.on{grid-template-columns:1fr}
  .sv-vis{display:none}
  .ab-grid{grid-template-columns:1fr}
  .ab-badge{display:none}
  .iso{flex-direction:column;text-align:center;gap:28px;padding:48px 24px}
  .iso-v{text-align:center}
  .con-h{letter-spacing:-1px}
  .contact{padding:100px 24px}
  .con-row{flex-wrap:wrap}
  .cd{min-width:140px;border:none;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.06)}
  .cd:last-child{border-bottom:none}
}
@media(max-width:480px){
  .awards-grid,.vals-g,.sust-pillars{grid-template-columns:1fr}
  .h-stats{grid-template-columns:1fr}
  .ig-row{grid-template-columns:1fr}
  .ig-big{grid-template-columns:1fr}
  .h-btns{flex-direction:column;align-items:flex-start}
  .team-g{grid-template-columns:1fr}
}
