*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --white:#ffffff;
  --off:#fafaf8;
  --off2:#f4f2ee;
  --gold:#b8922a;
  --gold2:#d4aa45;
  --gold3:#e8c96a;
  --gold-pale:#fdf6e3;
  --gold-line:rgba(184,146,42,0.15);
  --ink:#1a1710;
  --ink2:#17150f;
  --muted:#7a7265;
  --muted2:#b0a898;
}
html{scroll-behavior:smooth;}
body{background:var(--white);color:var(--ink);font-family:"Outfit",sans-serif;font-weight:300;overflow-x:hidden;}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar{width:3px;}
::-webkit-scrollbar-track{background:var(--off);}
::-webkit-scrollbar-thumb{background:var(--gold2);}

/* ════════════════════════════════
   NAV
════════════════════════════════ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.4rem 5rem;
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--gold-line);
  transition:padding 0.3s,box-shadow 0.3s;
}
nav.scrolled{padding:0.9rem 5rem;box-shadow:0 4px 30px rgba(0,0,0,0.06);}
.nav-logo{
  font-family:"Playfair Display",serif;font-size:1.3rem;font-weight:700;
  letter-spacing:0.1em;color:var(--ink);text-decoration:none;
}
.nav-logo em{font-style:normal;color:var(--gold);}
.nav-links{display:flex;gap:2.8rem;list-style:none;}
.nav-links a{
  font-size:0.72rem;font-weight:400;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;transition:color 0.25s;
  position:relative;
}
.nav-links a::after{
  content:"";position:absolute;bottom:-4px;left:0;width:0;height:1px;
  background:var(--gold);transition:width 0.3s;
}
.nav-links a:hover{color:var(--gold);}
.nav-links a:hover::after{width:100%;}
.nav-cta{
  font-size:0.7rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;
  background:var(--ink2);color:var(--white);padding:0.6rem 1.6rem;
  border-radius:100px;text-decoration:none;transition:background 0.25s,transform 0.2s;
}
.nav-cta:hover{background:var(--gold);transform:translateY(-1px);}

/* Hamburger */
.nav-hamburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:36px;height:36px;cursor:pointer;padding:4px;
  background:none;border:none;
}
.nav-hamburger span{
  display:block;width:22px;height:2px;background:var(--ink);
  border-radius:2px;transition:transform 0.35s,opacity 0.25s,width 0.25s;
  transform-origin:center;
}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-hamburger.open span:nth-child(2){opacity:0;width:0;}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* Mobile Drawer */
.mobile-menu{
  position:fixed;inset:0;z-index:999;
  background:var(--ink2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.2rem;
  transform:translateX(100%);transition:transform 0.45s cubic-bezier(0.25,0.46,0.45,0.94);
  padding:2rem;
}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu a{
  font-family:"Playfair Display",serif;font-size:2rem;font-weight:700;font-style:italic;
  color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.25s;letter-spacing:0.02em;
}
.mobile-menu a:hover{color:var(--gold3);}
.mobile-menu .m-cta{
  font-family:"Outfit",sans-serif;font-size:0.72rem;font-style:normal;font-weight:500;
  letter-spacing:0.2em;text-transform:uppercase;
  background:var(--gold);color:#fff;padding:0.8rem 2.4rem;
  border-radius:100px;margin-top:1rem;
}
.mob-decor{
  position:absolute;bottom:3rem;
  font-size:0.6rem;letter-spacing:0.3em;text-transform:uppercase;
  color:rgba(255,255,255,0.15);
}

/* ════════════════════════════════
   HERO
════════════════════════════════ */
#hero{
  min-height:100vh;
  display:grid;grid-template-columns:1fr 1fr;align-items:center;
  position:relative;overflow:hidden;background:#080704;
  padding-top:80px;
}
.hero-bg-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(184,146,42,0.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(184,146,42,0.04) 1px,transparent 1px);
  background-size:60px 60px;
}
.hero-left{
  position:relative;z-index:2;
  padding:4rem 3rem 4rem 5rem;
  display:flex;flex-direction:column;justify-content:center;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:0.8rem;
  font-size:0.57rem;font-weight:600;letter-spacing:0.45em;text-transform:uppercase;
  color:var(--gold2);margin-bottom:1.1rem;
  opacity:0;animation:fadeUp 0.7s 0.2s forwards;
}
.hero-eyebrow span{display:block;width:26px;height:1px;background:var(--gold2);}
.hero-tag{
  display:inline-flex;align-items:center;gap:0.6rem;
  background:rgba(184,146,42,0.1);border:1px solid rgba(184,146,42,0.2);
  border-radius:100px;padding:0.35rem 1rem 0.35rem 0.6rem;
  font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold2);
  margin-bottom:1.4rem;width:fit-content;
  opacity:0;animation:fadeUp 0.7s 0.1s forwards;
}
.hero-tag-dot{width:6px;height:6px;background:var(--gold2);border-radius:50%;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.4;}}
.hero-h1{
  font-family:"Playfair Display",serif;
  font-size:clamp(2rem,3.8vw,3.4rem);
  font-weight:700;line-height:1.1;letter-spacing:-0.02em;
  color:#fff;margin-bottom:1rem;
  opacity:0;animation:fadeUp 1s 0.4s forwards;
}
.hero-h1 em{font-style:italic;color:var(--gold3);}
.hero-body{
  font-size:0.87rem;font-weight:300;color:rgba(255,255,255,0.42);
  line-height:1.75;max-width:360px;margin-bottom:2rem;
  opacity:0;animation:fadeUp 0.7s 0.7s forwards;
}
.hero-btns{
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem;
  opacity:0;animation:fadeUp 0.7s 0.9s forwards;
}
.btn-gold{
  font-size:0.63rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;
  background:var(--gold);color:#fff;padding:0.72rem 1.8rem;border-radius:100px;
  text-decoration:none;transition:background 0.25s,transform 0.25s;
  box-shadow:0 4px 18px rgba(184,146,42,0.35);
}
.btn-gold:hover{background:var(--gold2);transform:translateY(-2px);}
.btn-outline{
  font-size:0.63rem;font-weight:400;letter-spacing:0.15em;text-transform:uppercase;
  color:rgba(255,255,255,0.5);text-decoration:none;
  border:1px solid rgba(255,255,255,0.16);padding:0.72rem 1.6rem;border-radius:100px;
  transition:border-color 0.25s,color 0.25s;
}
.btn-outline:hover{border-color:var(--gold2);color:var(--gold2);}
.hero-kpis{
  display:flex;gap:0;
  opacity:0;animation:fadeUp 0.7s 1.1s forwards;
}
.kpi{
  padding:0 1.8rem;border-right:1px solid rgba(255,255,255,0.09);
  display:flex;flex-direction:column;gap:0.2rem;
}
.kpi:first-child{padding-left:0;}
.kpi:last-child{border-right:none;}
.kpi-n{font-family:"Playfair Display",serif;font-size:1.8rem;font-weight:700;color:var(--gold3);line-height:1;}
.kpi-l{font-size:0.54rem;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.28);}

/* Hero Right - Dashboard */
.hero-right{
  position:relative;z-index:2;display:flex;align-items:center;
  justify-content:center;height:100%;padding:4rem 4rem 4rem 1rem;
}
.hero-visual{
  position:relative;width:310px;height:410px;
  opacity:0;animation:fadeUp 1.2s 0.6s forwards;
}
.vis-glow{
  position:absolute;top:50%;left:50%;width:280px;height:280px;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(184,146,42,0.15) 0%,transparent 70%);
  border-radius:50%;animation:glowPulse 3s ease-in-out infinite;z-index:0;
}
@keyframes glowPulse{0%,100%{opacity:0.5;transform:translate(-50%,-50%) scale(1);}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2);}}
.vis-card{
  position:absolute;inset:0;
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);
  border-radius:22px;backdrop-filter:blur(18px);overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.05);z-index:1;
}
.vis-card-header{
  padding:1rem 1.4rem;border-bottom:1px solid rgba(255,255,255,0.06);
  display:flex;align-items:center;gap:0.8rem;
}
.vis-dots{display:flex;gap:0.4rem;}
.vis-dot{width:7px;height:7px;border-radius:50%;}
.vis-dot:nth-child(1){background:#ff5f57;}
.vis-dot:nth-child(2){background:#febc2e;}
.vis-dot:nth-child(3){background:#28c840;}
.vis-card-title{font-size:0.6rem;letter-spacing:0.15em;text-transform:uppercase;color:rgba(255,255,255,0.25);}
.vis-card-body{padding:1.1rem 1.4rem;display:flex;flex-direction:column;gap:0.9rem;}
.vis-chart{display:flex;align-items:flex-end;gap:0.45rem;height:72px;}
.vis-bar{
  flex:1;border-radius:4px 4px 0 0;
  background:linear-gradient(to top,var(--gold),var(--gold3));opacity:0.75;
  transform:scaleY(0);transform-origin:bottom;animation:barGrow 1.6s ease-out forwards;
}
.vis-bar:nth-child(1){height:38%;animation-delay:0.8s;}
.vis-bar:nth-child(2){height:60%;animation-delay:0.95s;}
.vis-bar:nth-child(3){height:45%;animation-delay:1.1s;}
.vis-bar:nth-child(4){height:82%;animation-delay:1.25s;}
.vis-bar:nth-child(5){height:65%;animation-delay:1.4s;}
.vis-bar:nth-child(6){height:92%;animation-delay:1.55s;}
.vis-bar:nth-child(7){height:75%;animation-delay:1.7s;}
@keyframes barGrow{from{transform:scaleY(0);}to{transform:scaleY(1);}}
.vis-stat-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:0.55rem 0.75rem;
  background:rgba(255,255,255,0.03);border-radius:8px;border:1px solid rgba(255,255,255,0.05);
}
.vis-stat-label{font-size:0.62rem;color:rgba(255,255,255,0.35);}
.vis-stat-val{font-family:"Playfair Display",serif;font-size:0.9rem;font-weight:700;color:var(--gold3);}
.vis-stat-badge{
  font-size:0.52rem;background:rgba(40,200,80,0.12);color:#28c850;
  border:1px solid rgba(40,200,80,0.2);padding:0.12rem 0.45rem;border-radius:100px;
}
.vis-progress-wrap{display:flex;flex-direction:column;gap:0.55rem;}
.vis-progress-item{display:flex;flex-direction:column;gap:0.28rem;}
.vis-progress-label{display:flex;justify-content:space-between;font-size:0.56rem;color:rgba(255,255,255,0.3);}
.vis-progress-bar{height:3px;background:rgba(255,255,255,0.06);border-radius:100px;overflow:hidden;}
.vis-progress-fill{
  height:100%;border-radius:100px;
  background:linear-gradient(to right,var(--gold),var(--gold3));
  transform:scaleX(0);transform-origin:left;animation:fillBar 1.6s ease-out forwards;
}
.vis-progress-item:nth-child(1) .vis-progress-fill{animation-delay:1.3s;width:88%;}
.vis-progress-item:nth-child(2) .vis-progress-fill{animation-delay:1.5s;width:74%;}
.vis-progress-item:nth-child(3) .vis-progress-fill{animation-delay:1.7s;width:92%;}
@keyframes fillBar{from{transform:scaleX(0);}to{transform:scaleX(1);}}
.vis-badge-float{
  position:absolute;top:-14px;right:-14px;
  background:linear-gradient(135deg,var(--gold),var(--gold2));border-radius:14px;
  padding:0.6rem 0.9rem;box-shadow:0 6px 20px rgba(184,146,42,0.4);
  animation:floatY 3s ease-in-out infinite;z-index:3;
}
.vis-notif{
  position:absolute;bottom:-12px;left:-18px;
  background:rgba(18,15,10,0.92);border:1px solid rgba(184,146,42,0.22);
  border-radius:12px;padding:0.6rem 0.9rem;
  display:flex;align-items:center;gap:0.65rem;backdrop-filter:blur(12px);
  animation:floatY 3.5s 1s ease-in-out infinite;z-index:3;min-width:160px;
}
@keyframes floatY{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
.vis-badge-float .vb-num{font-family:"Playfair Display",serif;font-size:1.3rem;font-weight:700;color:#fff;line-height:1;}
.vis-badge-float .vb-label{font-size:0.48rem;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.7);}
.vis-notif-dot{width:7px;height:7px;background:#28c850;border-radius:50%;flex-shrink:0;box-shadow:0 0 7px #28c850;}
.vis-notif-text{font-size:0.58rem;color:rgba(255,255,255,0.55);line-height:1.4;}
.vis-notif-text strong{color:#fff;display:block;font-size:0.62rem;}

.hero-scroll{
  position:absolute;bottom:1.8rem;left:5rem;z-index:2;
  display:flex;align-items:center;gap:0.7rem;
  font-size:0.54rem;letter-spacing:0.28em;text-transform:uppercase;color:rgba(255,255,255,0.22);
  opacity:0;animation:fadeIn 1s 1.8s forwards;
}
.h-line{width:30px;height:1px;background:linear-gradient(to right,var(--gold2),transparent);animation:hlinePulse 2s 2.2s ease-in-out infinite;}
@keyframes hlinePulse{0%,100%{width:30px;opacity:0.3;}50%{width:10px;opacity:1;}}

/* ════════════════════════════════
   TICKER
════════════════════════════════ */
.ticker-belt{
  overflow:hidden;padding:1.4rem 0;background:var(--ink2);
  border-top:1px solid rgba(255,255,255,0.04);border-bottom:1px solid rgba(255,255,255,0.04);
}
.ticker-track{display:flex;align-items:center;width:max-content;animation:ticker 25s linear infinite;}
.ti{
  font-family:"Playfair Display",serif;font-size:1rem;font-style:italic;
  color:rgba(255,255,255,0.4);white-space:nowrap;padding:0 2rem;
  display:flex;align-items:center;gap:2rem;
}
.ti::after{content:"✦";font-size:0.5rem;font-style:normal;color:var(--gold2);}
@keyframes ticker{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ════════════════════════════════
   SECTION COMMONS
════════════════════════════════ */
.sec{padding:8rem 5rem;}
.sec-label{
  display:inline-flex;align-items:center;gap:0.8rem;
  font-size:0.62rem;font-weight:500;letter-spacing:0.35em;text-transform:uppercase;color:var(--gold);
}
.sec-label::before{content:"";display:block;width:24px;height:1px;background:var(--gold);}
.sec-h{
  font-family:"Playfair Display",serif;font-size:clamp(2rem,4vw,3.5rem);
  font-weight:700;line-height:1.1;margin-top:0.8rem;
}
.sec-h em{font-style:italic;color:var(--gold);}
.sec-p{font-size:0.92rem;color:var(--muted);line-height:1.85;margin-top:0.9rem;max-width:480px;}

/* ════════════════════════════════
   CLIENTS
════════════════════════════════ */
#clients{background:var(--white);}
.cl-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4rem;flex-wrap:wrap;gap:2rem;}
.cl-badge{display:flex;flex-direction:column;align-items:flex-end;}
.cl-big{
  font-family:"Playfair Display",serif;font-size:5rem;font-weight:700;line-height:1;
  background:linear-gradient(135deg,var(--gold),var(--gold3));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.cl-big-l{font-size:0.65rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--muted2);text-align:right;margin-top:0.2rem;}
.cl-table{width:100%;}
.cl-thead{
  display:grid;grid-template-columns:56px 1.2fr 2fr 1.3fr 50px;
  gap:1rem;padding:0.8rem 1.8rem;border-bottom:1.5px solid var(--ink);margin-bottom:0.5rem;
}
.cl-th{font-size:0.6rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--muted2);font-weight:500;}
.cl-row{
  display:grid;grid-template-columns:56px 1.2fr 2fr 1.3fr 50px;
  gap:1rem;padding:1.8rem;border-bottom:1px solid var(--gold-line);align-items:center;
  position:relative;overflow:hidden;cursor:pointer;
  opacity:0;transform:translateY(16px);transition:opacity 0.5s,transform 0.5s,background 0.3s;
}
.cl-row.on{opacity:1;transform:translateY(0);}
.cl-row::after{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(to bottom,var(--gold),var(--gold3));
  transform:scaleY(0);transform-origin:bottom;transition:transform 0.35s cubic-bezier(0.25,0.46,0.45,0.94);
}
.cl-row:hover{background:var(--gold-pale);}
.cl-row:hover::after{transform:scaleY(1);}
.r-num{font-family:"Playfair Display",serif;font-size:1.2rem;font-weight:400;font-style:italic;color:var(--muted2);transition:color 0.25s;}
.cl-row:hover .r-num{color:var(--gold);}
.r-name{font-family:"Playfair Display",serif;font-size:1.3rem;font-weight:700;color:var(--ink);transition:color 0.25s;}
.cl-row:hover .r-name{color:var(--gold);}
.r-tags{display:flex;flex-wrap:wrap;gap:0.4rem;}
.r-tag{
  font-size:0.6rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;
  padding:0.25rem 0.7rem;border:1px solid var(--gold-line);color:var(--muted);border-radius:100px;transition:all 0.25s;
}
.cl-row:hover .r-tag{border-color:var(--gold2);color:var(--gold);background:rgba(184,146,42,0.06);}
.r-profit{font-family:"Playfair Display",serif;font-size:1rem;font-style:italic;color:var(--gold);}
.r-arr{font-size:1rem;color:var(--muted2);transition:transform 0.3s,color 0.25s;}
.cl-row:hover .r-arr{transform:translate(3px,-3px);color:var(--gold);}

/* ════════════════════════════════
   SERVICES
════════════════════════════════ */
#services{background:var(--ink2);}
#services .sec-label{color:var(--gold2);}
#services .sec-label::before{background:var(--gold2);}
#services .sec-h{color:var(--white);}
#services .sec-p{color:rgba(255,255,255,0.38);}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px;margin-top:4.5rem;}
.svc-card{
  background:rgba(255,255,255,0.025);border:1px solid rgba(255,255,255,0.05);
  padding:2.8rem 2.2rem;position:relative;overflow:hidden;
  transition:background 0.35s,transform 0.35s;
}
.svc-card:hover{background:rgba(255,255,255,0.055);transform:translateY(-5px);}
.svc-card::before{
  content:"";position:absolute;bottom:0;left:0;right:0;height:1.5px;
  background:linear-gradient(to right,var(--gold),var(--gold3));
  transform:scaleX(0);transform-origin:left;transition:transform 0.45s;
}
.svc-card:hover::before{transform:scaleX(1);}
.svc-n{
  font-family:"Playfair Display",serif;font-size:4rem;font-weight:700;font-style:italic;
  color:rgba(255,255,255,0.03);position:absolute;top:0.5rem;right:1.2rem;line-height:1;
}
.svc-ico{
  width:40px;height:40px;border:1px solid rgba(184,146,42,0.25);border-radius:10px;
  display:flex;align-items:center;justify-content:center;color:var(--gold2);
  margin-bottom:1.8rem;background:rgba(184,146,42,0.05);
}
.svc-title{font-family:"Playfair Display",serif;font-size:1.15rem;font-weight:700;color:var(--white);margin-bottom:0.7rem;}
.svc-desc{font-size:0.8rem;line-height:1.85;color:rgba(255,255,255,0.36);}


/* PORTFOLIO */
#portfolio {
  background: var(--white);
}
.port-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.2rem;
  margin-top: 4rem;
}
.port-item {
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  aspect-ratio: 4/3;
  cursor: none;
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.5s,
    transform 0.5s;
}
.port-item.on {
  opacity: 1;
  transform: translateY(0);
}
.port-item:nth-child(5),
.port-item:nth-child(6) {
  grid-column: span 1;
}
.port-row2 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.2rem;
  margin-top: 1.2rem;
}
.port-row2 .port-item {
  grid-column: span 1;
}
.port-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  display: block;
}
.port-item:hover img {
  transform: scale(1.08);
}
.port-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(10, 8, 4, 0.85) 0%,
    rgba(10, 8, 4, 0.1) 60%,
    transparent 100%
  );
  display: flex;
  align-items: flex-end;
  padding: 1.2rem 1.4rem;
  opacity: 0;
  transition: opacity 0.35s;
}
.port-item:hover .port-overlay {
  opacity: 1;
}
.port-label {
  font-family: "Playfair Display", serif;
  font-size: 0.95rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.02em;
}
.port-tag {
  font-size: 0.55rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold3);
  margin-bottom: 0.3rem;
}

/* ════════════════════════════════
   FAQ
════════════════════════════════ */
#faq{background:var(--white);}
.faq-list{margin-top:4rem;display:flex;flex-direction:column;border-top:1px solid var(--gold-line);}
.faq-item{border-bottom:1px solid var(--gold-line);overflow:hidden;}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;
  padding:1.8rem 0;cursor:pointer;transition:color 0.25s;
}
.faq-q:hover{color:var(--gold);}
.faq-q-text{font-family:"Playfair Display",serif;font-size:1.1rem;font-weight:700;color:var(--ink);transition:color 0.25s;}
.faq-q:hover .faq-q-text{color:var(--gold);}
.faq-icon{
  width:28px;height:28px;border:1px solid var(--gold-line);border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background 0.25s,border-color 0.25s;
}
.faq-q:hover .faq-icon{border-color:var(--gold2);background:rgba(184,146,42,0.07);}
.faq-icon svg{transition:transform 0.35s;}
.faq-item.open .faq-icon{background:var(--gold);border-color:var(--gold);}
.faq-item.open .faq-icon svg{transform:rotate(45deg);}
.faq-item.open .faq-icon svg path{stroke:#fff;}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.45s cubic-bezier(0.25,0.46,0.45,0.94);}
.faq-a-inner{font-size:0.88rem;color:var(--muted);line-height:1.85;padding:0 0 1.6rem;max-width:680px;}
.faq-item.open .faq-a{max-height:220px;}

/* ════════════════════════════════
   CONTACT
════════════════════════════════ */
#contact{background:var(--ink2);}
#contact .sec-label{color:var(--gold2);}
#contact .sec-label::before{background:var(--gold2);}
#contact .sec-h{color:var(--white);}
#contact .sec-p{color:rgba(255,255,255,0.38);}
.contact-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:6rem;margin-top:4.5rem;align-items:start;}
.contact-info{display:flex;flex-direction:column;gap:2.2rem;}
.ci-item{display:flex;align-items:flex-start;gap:1.2rem;}
.ci-icon{
  width:40px;height:40px;border:1px solid rgba(184,146,42,0.25);border-radius:10px;
  display:flex;align-items:center;justify-content:center;color:var(--gold2);
  flex-shrink:0;background:rgba(184,146,42,0.05);
}
.ci-label{font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:0.3rem;}
.ci-val{font-family:"Playfair Display",serif;font-size:1rem;color:var(--white);}
.contact-form{display:flex;flex-direction:column;gap:1.1rem;}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;}
.cf-input,.cf-textarea{
  width:100%;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
  border-radius:10px;padding:0.9rem 1.2rem;font-family:"Outfit",sans-serif;
  font-size:0.82rem;font-weight:300;color:var(--white);outline:none;
  transition:border-color 0.25s,background 0.25s;
}
.cf-input::placeholder,.cf-textarea::placeholder{color:rgba(255,255,255,0.25);}
.cf-input:focus,.cf-textarea:focus{border-color:var(--gold2);background:rgba(184,146,42,0.04);}
.cf-textarea{resize:vertical;min-height:130px;}
.cf-btn{
  align-self:flex-start;font-family:"Outfit",sans-serif;
  font-size:0.65rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;
  background:var(--gold);color:#fff;padding:0.78rem 2rem;border-radius:100px;
  border:none;cursor:pointer;transition:background 0.25s,transform 0.25s;
  box-shadow:0 4px 18px rgba(184,146,42,0.25);
}
.cf-btn:hover{background:var(--gold2);transform:translateY(-2px);}

/* ════════════════════════════════
   FOOTER
════════════════════════════════ */
footer{
  background:var(--ink2);padding:3rem 5rem;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem;
  border-top:1px solid rgba(184,146,42,0.1);
}
.f-logo-text{font-family:"Playfair Display",serif;font-size:1.3rem;font-weight:700;letter-spacing:0.1em;color:var(--white);}
.f-logo-text em{font-style:normal;color:var(--gold);}
.f-copy{font-size:0.68rem;color:rgba(255,255,255,0.25);letter-spacing:0.12em;}
.f-links{display:flex;gap:1.8rem;}
.f-links a{
  font-size:0.65rem;letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(255,255,255,0.28);text-decoration:none;transition:color 0.25s;
}
.f-links a:hover{color:var(--gold2);}

/* ════════════════════════════════
   ANIMATIONS
════════════════════════════════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.reveal{opacity:0;transform:translateY(30px);transition:opacity 0.75s cubic-bezier(0.25,0.46,0.45,0.94),transform 0.75s cubic-bezier(0.25,0.46,0.45,0.94);}
.reveal.on{opacity:1;transform:translateY(0);}
.rd1{transition-delay:0.1s;}
.rd2{transition-delay:0.2s;}
.rd3{transition-delay:0.3s;}
.rd4{transition-delay:0.4s;}

/* ════════════════════════════════
   RESPONSIVE — 1200px
════════════════════════════════ */
@media(max-width:1200px){
  .port-grid{grid-template-columns:repeat(3,1fr);}
}

/* ════════════════════════════════
   RESPONSIVE — 1050px (Tablet)
════════════════════════════════ */
@media(max-width:1050px){
  nav{padding:1.2rem 2.5rem;}
  nav.scrolled{padding:0.8rem 2.5rem;}
  .sec{padding:6rem 2.5rem;}
  footer{padding:2.5rem;}
  .svc-grid{grid-template-columns:1fr 1fr;}
  .cl-thead,.cl-row{grid-template-columns:44px 1fr 1.5fr 1fr;}
  .r-arr{display:none;}
  .contact-layout{grid-template-columns:1fr;gap:3rem;}
}

/* ════════════════════════════════
   RESPONSIVE — 820px
════════════════════════════════ */
@media(max-width:820px){
  #hero{grid-template-columns:1fr;}
  .hero-right{display:none;}
  .hero-left{padding:3rem 2rem 3rem 2rem;}
  .hero-scroll{left:2rem;}
  nav{padding:1rem 1.5rem;}
  nav.scrolled{padding:0.7rem 1.5rem;}
  .nav-links,.nav-cta{display:none;}
  .nav-hamburger{display:flex;}
  .port-grid{grid-template-columns:repeat(2,1fr);}
  .cl-thead{display:none;}
  .cl-row{
    grid-template-columns:1fr;padding:1.2rem 1rem;gap:0.5rem;
  }
  .r-num{display:none;}
  .svc-grid{grid-template-columns:1fr 1fr;}
}

/* ════════════════════════════════
   RESPONSIVE — 600px (Mobile)
════════════════════════════════ */
@media(max-width:600px){
  nav{padding:1rem 1.2rem;}
  .sec{padding:5rem 1.4rem;}
  .hero-left{padding:2.5rem 1.4rem;}
  .hero-h1{font-size:clamp(1.9rem,8vw,2.5rem);}
  .hero-kpis{flex-wrap:wrap;}
  .kpi{padding:0.6rem 1.4rem 0.6rem 0;border-right:none;}
  .kpi:nth-child(2){border-left:1px solid rgba(255,255,255,0.09);padding-left:1.4rem;}
  .cl-big{font-size:3.5rem;}
  .svc-grid{grid-template-columns:1fr;}
  .port-grid{grid-template-columns:1fr 1fr;}
  .cf-row{grid-template-columns:1fr;}
  .cl-head{flex-direction:column;align-items:flex-start;}
  .cl-badge{align-items:flex-start;}
  .cl-big-l{text-align:left;}
  footer{flex-direction:column;text-align:center;gap:1.2rem;padding:2rem 1.4rem;}
  .f-links{gap:1.2rem;}
  .hero-scroll{display:none;}
  .contact-layout{gap:2.5rem;}
}

/* ════════════════════════════════
   RESPONSIVE — 380px (Small phones)
════════════════════════════════ */
@media(max-width:380px){
  .port-grid{grid-template-columns:1fr;}
  .hero-btns{flex-direction:column;align-items:flex-start;}
  .btn-gold,.btn-outline{width:100%;text-align:center;}
}
