/* ════════════════════════════════════════════════════════
   Components — reusable across public & admin
   ════════════════════════════════════════════════════════ */

/* Section labels & titles */
.sec-label{
  font-size:.5rem;
  font-weight:700;
  color:var(--cyan);
  letter-spacing:.2em;
  text-transform:uppercase;
  margin-bottom:var(--s-3);
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.sec-label::before{content:'';width:24px;height:.5px;background:rgba(0,195,212,.4)}
.sec-title{
  font-size:clamp(1.625rem,3.5vw,2.25rem);
  font-weight:800;
  color:var(--txt);
  letter-spacing:-.045em;
  line-height:1.1;
  margin-bottom:var(--s-3);
}
.sec-title em{color:var(--cyan);font-style:normal}
.sec-title.light{color:#fff}
.sec-sub{
  font-size:.9375rem;
  color:var(--txt-3);
  line-height:1.7;
  max-width:520px;
  margin:0 auto;
}
.sec-sub.light{color:var(--txt-d)}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:.875rem;
  font-weight:700;
  padding:.75rem 1.5rem;
  border-radius:var(--r);
  transition:all .2s;
  cursor:pointer;
}
.btn-cyan{background:var(--cyan);color:var(--ink)}
.btn-cyan:hover{background:var(--cyan-h);transform:translateY(-1px)}
.btn-outline{border:.5px solid var(--bd-2);color:var(--txt-2);background:#fff}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan)}

/* Ghost button on dark surfaces */
.btn-ghost-d{
  font-size:.6875rem;
  font-weight:600;
  color:rgba(255,255,255,.5);
  padding:.4rem .875rem;
  border:.5px solid var(--line-d-2);
  border-radius:5px;
  display:inline-flex;
  align-items:center;
  gap:5px;
  transition:all .2s;
}
.btn-ghost-d:hover{color:#fff;border-color:rgba(255,255,255,.3)}

/* Back button */
.det-back{
  display:flex;
  align-items:center;
  gap:6px;
  font-size:.8125rem;
  font-weight:600;
  color:var(--txt-2);
  padding:.4rem .875rem;
  border:.5px solid var(--bd);
  border-radius:var(--r-sm);
  transition:all .2s;
}
.det-back:hover{border-color:var(--cyan);color:var(--cyan)}

/* Cards */
.card{
  background:#fff;
  border:.5px solid var(--bd);
  border-radius:var(--r-lg);
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;
}
.card-hover:hover{
  transform:translateY(-3px);
  border-color:rgba(0,195,212,.3);
  box-shadow:var(--shadow);
}

/* Empty state */
.empty{
  text-align:center;
  padding:var(--s-7) var(--s-6);
  color:var(--txt-3);
  grid-column:1/-1;
}
.empty i{font-size:2.5rem;opacity:.2;display:block;margin-bottom:var(--s-3)}
.empty p{font-size:.875rem}

/* Hero — public */
.pub-hero{
  background:var(--ink);
  padding:var(--s-8) var(--s-6) calc(var(--s-8) - 1rem);
  text-align:center;
  border-bottom:.5px solid var(--line-d);
}
.pub-hero-label{
  font-size:.5rem;
  font-weight:700;
  color:rgba(0,195,212,.7);
  letter-spacing:.2em;
  text-transform:uppercase;
  margin-bottom:var(--s-4);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.pub-hero-label::before,.pub-hero-label::after{
  content:'';width:24px;height:.5px;background:rgba(0,195,212,.4);
}
.pub-hero-title{
  font-size:clamp(2rem,5vw,3.25rem);
  font-weight:800;
  color:#fff;
  letter-spacing:-.05em;
  line-height:1.05;
  margin-bottom:var(--s-4);
  max-width:760px;
  margin-left:auto;
  margin-right:auto;
}
.pub-hero-title em{color:var(--cyan);font-style:normal}
.pub-hero-sub{
  font-size:.9375rem;
  color:rgba(255,255,255,.45);
  max-width:540px;
  margin:0 auto;
  line-height:1.75;
}

/* About */
.about{background:var(--white);border-bottom:.5px solid var(--bd)}
.about-inner{
  max-width:1100px;
  margin:0 auto;
  padding:0 var(--s-6);
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:var(--s-8);
  align-items:center;
}
.about-content h2{
  font-size:clamp(1.75rem,3.5vw,2.375rem);
  font-weight:800;
  letter-spacing:-.045em;
  line-height:1.1;
  margin-bottom:var(--s-4);
}
.about-content h2 em{color:var(--cyan);font-style:normal}
.about-content p{font-size:.9375rem;line-height:1.85;color:var(--txt-3)}
.about-stats{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:var(--bd);
  border:.5px solid var(--bd);
  border-radius:var(--r-md);
  overflow:hidden;
}
.about-stat{background:#fff;padding:var(--s-5) var(--s-4);text-align:center}
.about-stat-v{
  font-size:clamp(1.875rem,4vw,2.5rem);
  font-weight:800;
  color:var(--cyan);
  letter-spacing:-.06em;
  line-height:1;
  font-family:var(--f-mono);
}
.about-stat-l{
  font-size:.5rem;
  font-weight:600;
  color:var(--txt-3);
  text-transform:uppercase;
  letter-spacing:.14em;
  margin-top:.5rem;
}

/* Services */
.services{background:var(--fog);border-bottom:.5px solid var(--bd)}
.svc-card{
  background:#fff;
  border:.5px solid var(--bd);
  border-radius:var(--r-lg);
  padding:var(--s-5);
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;
}
.svc-card:hover{
  transform:translateY(-3px);
  border-color:rgba(0,195,212,.3);
  box-shadow:var(--shadow);
}
.svc-icon{
  width:44px;height:44px;
  background:rgba(0,195,212,.08);
  border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;
  font-size:1.25rem;color:var(--cyan);
  margin-bottom:var(--s-4);
}
.svc-title{
  font-size:.9375rem;
  font-weight:700;
  color:var(--txt);
  letter-spacing:-.02em;
  margin-bottom:var(--s-2);
  line-height:1.25;
}
.svc-desc{font-size:.8125rem;line-height:1.65;color:var(--txt-3)}

/* Verticals */
.verticals{background:var(--white);border-bottom:.5px solid var(--bd)}
.vert-card{
  position:relative;
  border-radius:var(--r-lg);
  overflow:hidden;
  background:var(--ink);
  min-height:280px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  transition:transform .35s var(--ease);
}
.vert-card:hover{transform:translateY(-4px)}
.vert-img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  opacity:.55;
  transition:transform .5s var(--ease),opacity .35s;
}
.vert-card:hover .vert-img{transform:scale(1.05);opacity:.7}
.vert-placeholder{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#0D1117,#1C2229);
  display:flex;align-items:center;justify-content:center;
}
.vert-placeholder i{font-size:3rem;color:rgba(0,195,212,.25)}
.vert-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.85),rgba(0,0,0,.4) 50%,transparent);
  z-index:1;
}
.vert-content{position:relative;z-index:2;padding:var(--s-5);color:#fff}
.vert-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;
  border-radius:var(--r-sm);
  background:rgba(0,195,212,.15);
  color:var(--cyan);
  margin-bottom:var(--s-3);
  font-size:1rem;
  border:.5px solid rgba(0,195,212,.3);
}
.vert-title{
  font-size:1.0625rem;
  font-weight:800;
  letter-spacing:-.025em;
  margin-bottom:var(--s-2);
  line-height:1.2;
}
.vert-desc{
  font-size:.8125rem;
  line-height:1.65;
  color:rgba(255,255,255,.7);
  margin-bottom:var(--s-3);
}
.vert-cta{
  font-size:.75rem;
  font-weight:700;
  color:var(--cyan);
  display:inline-flex;
  align-items:center;
  gap:5px;
  transition:gap .2s;
}
.vert-card:hover .vert-cta{gap:9px}

/* Portfolio cards */
.portfolio{background:var(--fog);border-bottom:.5px solid var(--bd)}
.pcard{
  background:#fff;
  border:.5px solid var(--bd);
  border-radius:var(--r-lg);
  overflow:hidden;
  cursor:pointer;
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;
  display:flex;
  flex-direction:column;
}
.pcard:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-l);
  border-color:rgba(0,195,212,.35);
}
.pcard-img{
  height:210px;
  position:relative;
  overflow:hidden;
  background:var(--ink-2);
}
.pcard-img img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .5s var(--ease);
}
.pcard:hover .pcard-img img{transform:scale(1.04)}
.pcard-placeholder{
  width:100%;height:100%;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:var(--s-3);
  background:linear-gradient(135deg,#0D1117,#161B22);
}
.pcard-placeholder i{font-size:1.875rem;color:rgba(255,255,255,.12)}
.pcard-placeholder span{
  font-size:.6875rem;color:rgba(255,255,255,.2);
  letter-spacing:.06em;font-family:var(--f-mono);
}
.pcard-cat{
  position:absolute;
  bottom:var(--s-3);left:var(--s-3);
  font-size:.4375rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:2px 8px;border-radius:3px;
  color:var(--ink);background:var(--cyan);
}
.pcard-body{padding:var(--s-5);flex:1;display:flex;flex-direction:column}
.pcard-title{
  font-size:.9375rem;font-weight:700;
  color:var(--txt);letter-spacing:-.02em;
  line-height:1.25;margin-bottom:var(--s-1);
}
.pcard-loc{
  font-size:.6875rem;color:var(--txt-3);
  display:flex;align-items:center;gap:4px;
  margin-bottom:var(--s-3);
}
.pcard-desc{
  font-size:.8rem;line-height:1.7;color:var(--txt-2);
  flex:1;margin-bottom:var(--s-4);
  display:-webkit-box;-webkit-line-clamp:3;
  -webkit-box-orient:vertical;overflow:hidden;
}
.pcard-chips{display:flex;flex-wrap:wrap;gap:var(--s-1);margin-bottom:var(--s-4)}
.pcard-chip{
  font-size:.5rem;font-weight:600;color:var(--txt-3);
  background:var(--fog-2);border:.5px solid var(--bd);
  border-radius:3px;padding:2px 7px;
}
.pcard-cta{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.75rem;font-weight:700;
  color:var(--cyan);margin-top:auto;
  transition:gap .2s;
}
.pcard:hover .pcard-cta{gap:9px}

/* Brands */
.brands{
  background:var(--ink);
  padding:var(--s-8) 0;
  overflow:hidden;
  border-bottom:.5px solid var(--line-d);
}
.brands .sec-label{color:rgba(0,195,212,.7)}
.brands-carousel{
  position:relative;width:100%;
  overflow:hidden;
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.brands-track{
  display:flex;gap:var(--s-4);
  animation:scroll-x 50s linear infinite;
  width:max-content;
}
.brands-carousel:hover .brands-track{animation-play-state:paused}
.brand-item{
  flex-shrink:0;
  width:200px;height:110px;
  background:rgba(255,255,255,.03);
  border:.5px solid var(--line-d);
  border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  padding:1.25rem;transition:all .3s;
}
.brand-item:hover{
  border-color:rgba(0,195,212,.3);
  background:rgba(255,255,255,.05);
}
.brand-item.has-link{cursor:pointer}
.brand-logo{max-width:100%;max-height:60px;object-fit:contain}
.brand-logo.grayscale{filter:grayscale(1) opacity(.7);transition:filter .3s}
.brand-item:hover .brand-logo.grayscale{filter:grayscale(0) opacity(1)}
.brand-logo.white{filter:brightness(0) invert(1) opacity(.7);transition:filter .3s}
.brand-item:hover .brand-logo.white{opacity:1}
.brand-text{text-align:center}
.brand-text-name{
  font-size:.875rem;font-weight:700;
  color:rgba(255,255,255,.65);
  letter-spacing:-.01em;line-height:1.2;
  margin-bottom:var(--s-1);
}
.brand-text-cat{
  font-size:.5rem;font-weight:600;
  color:rgba(0,195,212,.6);
  letter-spacing:.14em;text-transform:uppercase;
  font-family:var(--f-mono);
}
.brand-item:hover .brand-text-name{color:#fff}

/* CTA section */
.cta{
  background:var(--white);
  padding:var(--s-8) var(--s-6);
  text-align:center;
  border-bottom:.5px solid var(--bd);
}
.cta h2{
  font-size:clamp(1.5rem,3.5vw,2rem);
  font-weight:800;color:var(--txt);
  letter-spacing:-.045em;margin-bottom:var(--s-3);
  line-height:1.15;
}
.cta p{
  font-size:.9375rem;color:var(--txt-3);
  max-width:480px;margin:0 auto var(--s-6);
  line-height:1.7;
}

/* Detail view */
.det-hero{
  height:clamp(280px,45vh,500px);
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,#0D1117,#161B22);
}
.det-hero img{width:100%;height:100%;object-fit:cover}
.det-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.75),rgba(0,0,0,.1) 50%,transparent);
}
.det-hero-content{
  position:absolute;
  bottom:var(--s-7);left:var(--s-6);right:var(--s-6);
  max-width:820px;margin:0 auto;z-index:2;
}
.det-cat{
  font-size:.5rem;font-weight:700;
  color:rgba(255,255,255,.6);
  letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:var(--s-2);
}
.det-title{
  font-size:clamp(1.625rem,4vw,2.625rem);
  font-weight:800;color:#fff;
  letter-spacing:-.05em;line-height:1.05;
  margin-bottom:var(--s-2);
}
.det-loc{
  font-size:.8125rem;color:rgba(255,255,255,.55);
  display:flex;align-items:center;gap:5px;
}
.det-body{
  max-width:820px;margin:0 auto;
  padding:var(--s-7) var(--s-6) var(--s-8);
  width:100%;
}
.det-block{margin-bottom:var(--s-7)}
.det-block-label{
  font-size:.5rem;font-weight:700;
  color:var(--cyan);text-transform:uppercase;
  letter-spacing:.2em;margin-bottom:var(--s-4);
}
.det-block h2{
  font-size:1.5rem;font-weight:800;
  color:var(--txt);letter-spacing:-.04em;
  line-height:1.2;margin-bottom:var(--s-4);
}
.det-block p{
  font-size:1rem;line-height:1.85;
  color:var(--txt-2);white-space:pre-wrap;
}
.det-summary{
  font-size:1.125rem;line-height:1.75;
  color:var(--txt);font-weight:500;
  padding-bottom:var(--s-6);
  border-bottom:.5px solid var(--bd);
  margin-bottom:var(--s-7);
}
.det-metrics{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:.5px;background:var(--bd);
  border:.5px solid var(--bd);
  border-radius:var(--r-md);overflow:hidden;
}
.det-met{background:#fff;padding:var(--s-5);text-align:center}
.det-met-v{
  font-size:1.875rem;font-weight:800;
  color:var(--cyan);letter-spacing:-.06em;
  line-height:1;font-family:var(--f-mono);
}
.det-met-l{
  font-size:.5rem;font-weight:600;
  color:var(--txt-3);text-transform:uppercase;
  letter-spacing:.12em;margin-top:.375rem;
}
.det-stack{display:flex;flex-wrap:wrap;gap:var(--s-2)}
.det-stack-chip{
  font-size:.8125rem;font-weight:500;
  color:var(--txt-2);background:var(--fog);
  border:.5px solid var(--bd);
  border-radius:var(--r-sm);padding:.5rem 1rem;
}
.det-hl{
  display:flex;align-items:flex-start;
  gap:.875rem;padding:.875rem 0;
  border-bottom:.5px solid var(--fog);
}
.det-hl:last-child{border-bottom:none}
.det-hl-ic{
  width:34px;height:34px;
  background:rgba(0,195,212,.08);
  border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;
  color:var(--cyan);font-size:1rem;flex-shrink:0;
}
.det-hl-text{
  font-size:.875rem;line-height:1.7;
  color:var(--txt-2);flex:1;padding-top:6px;
}
.det-rel{display:flex;flex-wrap:wrap;gap:.625rem}
.det-rel-brand{
  font-size:.8125rem;font-weight:600;
  color:var(--txt);background:var(--fog);
  border:.5px solid var(--bd);
  border-radius:var(--r-sm);
  padding:.625rem 1rem;
  display:flex;align-items:center;gap:.5rem;
}
.det-rel-brand img{width:24px;height:24px;object-fit:contain}
.det-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-3)}
.det-gallery-img{
  aspect-ratio:4/3;border-radius:var(--r);
  overflow:hidden;background:var(--fog);cursor:zoom-in;
}
.det-gallery-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .3s;
}
.det-gallery-img:hover img{transform:scale(1.05)}
.det-doc{
  display:flex;align-items:center;
  gap:var(--s-3);padding:.875rem;
  border:.5px solid var(--bd);
  border-radius:var(--r);
  margin-bottom:var(--s-2);
  transition:border-color .2s;
}
.det-doc:hover{border-color:var(--cyan)}
.det-doc i{color:var(--cyan);font-size:1.125rem;flex-shrink:0}
.det-doc-title{font-size:.875rem;font-weight:500;color:var(--txt);flex:1}
.det-doc-link{
  font-size:.75rem;color:var(--cyan);
  display:flex;align-items:center;gap:4px;
}
.det-cta{
  margin-top:var(--s-7);padding:var(--s-7);
  background:var(--ink);border-radius:var(--r-lg);
  text-align:center;
}
.det-cta-title{
  font-size:1.25rem;font-weight:700;
  color:#fff;letter-spacing:-.03em;
  margin-bottom:var(--s-4);
}

/* Toast & Lightbox */
.toast{
  position:fixed;bottom:1.5rem;right:1.5rem;
  background:var(--ink);color:#fff;
  font-size:.8125rem;font-weight:500;
  padding:.75rem 1.25rem;border-radius:var(--r);
  border-left:3px solid var(--cyan);
  transform:translateY(60px);opacity:0;
  transition:all .35s var(--ease);
  z-index:9999;pointer-events:none;
}
.toast.show{transform:translateY(0);opacity:1}
.toast-err{border-left-color:var(--red)}

.lightbox{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.92);z-index:9000;
  align-items:center;justify-content:center;
}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--r-sm)}
.lightbox-close{
  position:fixed;top:1rem;right:1rem;
  color:#fff;font-size:1.5rem;cursor:pointer;
  background:rgba(255,255,255,.1);
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}

/* Lazy image fade */
.lazy-img{opacity:0;transition:opacity .35s var(--ease)}
.lazy-img.loaded{opacity:1}

/* ════════ Logo system ════════ */
.pub-nav-logo-img{
  height:38px;width:auto;max-width:200px;
  object-fit:contain;display:block;
}

/* ════════ Footer — enterprise structure ════════ */
.pub-footer{
  background:var(--ink);
  padding:var(--s-7) var(--s-6) var(--s-6);
  border-top:.5px solid var(--line-d);
}
.footer-inner{
  max-width:720px;margin:0 auto;
  text-align:center;
  display:flex;flex-direction:column;
  align-items:center;gap:var(--s-4);
}
.footer-brand{display:flex;align-items:center;justify-content:center}
.footer-logo{
  height:44px;width:auto;max-width:240px;
  object-fit:contain;
}
.footer-logo-text{
  font-size:1.125rem;font-weight:800;
  color:#fff;letter-spacing:-.03em;
}
.footer-logo-text span{color:var(--cyan)}
.footer-desc{
  font-size:.8125rem;line-height:1.7;
  color:rgba(255,255,255,.55);
  max-width:480px;margin:0;
}
.footer-contact{
  display:flex;flex-wrap:wrap;
  justify-content:center;align-items:center;
  gap:var(--s-2) var(--s-4);
  font-size:.8125rem;
}
.footer-link{
  display:inline-flex;align-items:center;gap:6px;
  color:rgba(255,255,255,.5);
  transition:color .2s;
}
.footer-link:hover{color:var(--cyan)}
.footer-link i{font-size:.9375rem;opacity:.7}
.footer-social-row{
  display:flex;gap:var(--s-2);
  margin-top:var(--s-2);
}
.footer-social{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;
  border-radius:50%;
  border:.5px solid var(--line-d-2);
  color:rgba(255,255,255,.55);
  font-size:1rem;
  transition:all .25s var(--ease);
}
.footer-social:hover{
  color:#fff;border-color:var(--cyan);
  background:rgba(0,195,212,.08);
  transform:translateY(-1px);
}
.footer-divider{
  width:60px;height:.5px;
  background:var(--line-d);
  margin-top:var(--s-2);
}
.footer-copy{
  font-size:.6875rem;
  color:rgba(255,255,255,.3);
  line-height:1.5;
}

/* Admin hint subtitle under labels */
.adm-hint{
  font-size:.625rem;color:var(--txt-3);
  margin:-.25rem 0 .5rem;line-height:1.5;
}

/* Admin logo preview — favicon variant uses 1:1 */
.adm-img-preview[style*="aspect-ratio:1"] img{
  padding:var(--s-3);
}
