/* ═══════════════════════════════════════════════
   TECHNOSIGNAGE — SHARED DESIGN SYSTEM
   White + Dark premium design with cyan/green accents
═══════════════════════════════════════════════ */

:root {
  /* Backgrounds */
  --bg:       #080C12;
  --bg2:      #0D1320;
  --surface:  #FFFFFF;
  --surface2: #F5F8FF;
  --surface3: #EBF0FF;

  /* Borders */
  --border-dark:  rgba(255,255,255,.08);
  --border-dark2: rgba(255,255,255,.14);
  --border-light: rgba(10,15,26,.1);
  --border-light2:rgba(10,15,26,.18);

  /* Text on dark */
  --text:  #FFFFFF;
  --text2: rgba(255,255,255,.62);
  --text3: rgba(255,255,255,.32);

  /* Text on white */
  --ink:  #0D1525;
  --ink2: #4A5A7A;
  --ink3: #8A9AB8;

  /* Accents */
  --cyan:  #00D4FF;
  --green: #00E5A0;
  --amber: #FFB340;
  --cyan-dim:  rgba(0,212,255,.12);
  --green-dim: rgba(0,229,160,.1);
  --amber-dim: rgba(255,179,64,.1);

  /* Gradients */
  --grad1: linear-gradient(135deg,#00D4FF,#00E5A0);
  --grad2: linear-gradient(135deg,#00E5A0,#00D4FF);

  /* Shadows */
  --shadow:   0 4px 24px rgba(10,15,26,.08);
  --shadow-lg: 0 16px 64px rgba(10,15,26,.14);

  /* Fonts */
  --ff-head: 'Syne', sans-serif;
  --ff-body: 'Outfit', sans-serif;

  /* Radii */
  --r:   12px;
  --rlg: 20px;
  --rxl: 28px;
}

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--ff-body); background:var(--bg); color:var(--text); overflow-x:hidden; font-size:16px; line-height:1.7; cursor:none; }
img  { display:block; max-width:100%; }
a    { text-decoration:none; color:inherit; }
ul   { list-style:none; }

/* ── Typography ── */
h1,h2,h3 { font-family:var(--ff-head); font-weight:700; line-height:1.1; letter-spacing:-.02em; }
h1 { font-size:clamp(3rem,7vw,5.5rem); }
h2 { font-size:clamp(2.2rem,4.5vw,3.5rem); }
h3 { font-size:clamp(1.1rem,2vw,1.5rem); letter-spacing:-.01em; }
h4 { font-family:var(--ff-head); font-size:1rem; font-weight:700; }
p  { line-height:1.75; }

/* ── Layout ── */
.container  { max-width:1200px; margin:0 auto; padding:0 40px; }
.section    { padding:120px 0; }
.section-sm { padding:80px 0; }

/* ── Labels ── */
.label {
  font-size:.72rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase;
  color:var(--cyan); margin-bottom:16px;
  display:flex; align-items:center; gap:10px;
}
.label::before { content:''; display:block; width:24px; height:1px; background:var(--cyan); }
.label-green { color:var(--green); }
.label-green::before { background:var(--green); }
.label-ink { color:var(--cyan); }

/* ── Gradient text ── */
.grad-text   { background:var(--grad1); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; background-size:200% auto; animation:shimmer 4s linear infinite; }
.grad-text-g { background:var(--grad2); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* ── Animations ── */
@keyframes shimmer    { 0%{background-position:-200% center} 100%{background-position:200% center} }
@keyframes float      { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
@keyframes orb1       { 0%,100%{transform:translate(0,0)} 33%{transform:translate(40px,-50px)} 66%{transform:translate(-30px,30px)} }
@keyframes orb2       { 0%,100%{transform:translate(0,0)} 33%{transform:translate(-50px,40px)} 66%{transform:translate(35px,-40px)} }
@keyframes pulse-ring { 0%{transform:scale(1);opacity:.6} 100%{transform:scale(2.4);opacity:0} }
@keyframes scanline   { 0%{transform:translateY(-100%)} 100%{transform:translateY(100vh)} }
@keyframes gflow      { 0%,100%{background-position:0% 0%} 50%{background-position:100% 100%} }

/* ── Noise + Grid overlay ── */
body::before {
  content:''; position:fixed; inset:0; z-index:1; pointer-events:none;
  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='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");
  opacity:.4;
}
.grid-lines {
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);
  background-size:80px 80px;
}

/* ── Cursor ── */
#cursor-dot  { width:8px; height:8px; background:#fff; border-radius:50%; position:fixed; transform:translate(-50%,-50%); pointer-events:none; z-index:9999; }
#cursor-ring { width:36px; height:36px; border:1.5px solid rgba(0,212,255,.7); border-radius:50%; position:fixed; transform:translate(-50%,-50%); transition:left .12s ease,top .12s ease,width .3s,height .3s; pointer-events:none; z-index:9998; }

/* ── Nav ── */
.nav { position:fixed; top:0; left:0; right:0; z-index:200; transition:all .4s; }
.nav.scrolled { background:rgba(8,12,18,.9); backdrop-filter:blur(24px); border-bottom:1px solid var(--border-dark); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:76px; max-width:1200px; margin:0 auto; padding:0 40px; }
.nav-logo  { display:flex; align-items:center; gap:12px; font-family:var(--ff-head); font-size:1.2rem; font-weight:800; color:#fff; }
.logo-mark { width:38px; height:38px; border-radius:10px; background:var(--grad1); display:flex; align-items:center; justify-content:center; font-size:.78rem; font-weight:800; color:#000; font-family:var(--ff-head); position:relative; overflow:hidden; flex-shrink:0; }
.logo-mark::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.3),transparent); }
.nav-links { display:flex; align-items:center; gap:32px; }
.nav-links a { font-size:.86rem; font-weight:500; color:rgba(255,255,255,.6); transition:color .25s; position:relative; }
.nav-links a::after { content:''; position:absolute; bottom:-4px; left:0; right:0; height:1px; background:var(--grad1); transform:scaleX(0); transform-origin:left; transition:transform .3s; }
.nav-links a:hover,
.nav-links a.active { color:#fff; }
.nav-links a:hover::after,
.nav-links a.active::after { transform:scaleX(1); }
.nav-cta { display:flex; gap:12px; }
.nav-toggle { display:none; cursor:pointer; background:none; border:none; padding:8px; }
.nav-toggle span { display:block; width:22px; height:1.5px; background:#fff; margin:5px 0; transition:.3s; }
.mnav-open .nav-links,
.mnav-open .nav-cta { display:flex; flex-direction:column; position:fixed; top:76px; left:0; right:0; background:var(--bg2); border-bottom:1px solid var(--border-dark); padding:24px 32px; gap:16px; z-index:199; }

/* ── Buttons ── */
.btn { display:inline-flex; align-items:center; gap:8px; padding:13px 28px; border-radius:50px; font-family:var(--ff-body); font-size:.88rem; font-weight:600; cursor:pointer; border:none; transition:all .25s; position:relative; overflow:hidden; }
.btn svg { width:16px; height:16px; transition:transform .3s; }
.btn:hover svg { transform:translateX(3px); }
.btn-glow { background:var(--grad1); color:#000; font-weight:700; }
.btn-glow::before { content:''; position:absolute; inset:-2px; background:var(--grad1); border-radius:50px; filter:blur(12px); opacity:0; transition:opacity .3s; z-index:-1; }
.btn-glow:hover::before { opacity:.7; }
.btn-glow:hover { transform:translateY(-2px); box-shadow:0 12px 40px rgba(0,212,255,.3); }
.btn-outline-light { background:transparent; color:#fff; border:1px solid rgba(255,255,255,.2); }
.btn-outline-light:hover { background:rgba(255,255,255,.06); border-color:var(--cyan); color:var(--cyan); transform:translateY(-2px); }
.btn-outline-dark { background:transparent; color:var(--ink); border:1px solid var(--border-light2); }
.btn-outline-dark:hover { background:var(--ink); color:#fff; border-color:var(--ink); transform:translateY(-2px); }

/* ── Page hero banner (inner pages) ── */
.page-hero { padding:160px 0 90px; background:var(--bg2); border-bottom:1px solid var(--border-dark); position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 70% 60% at 50% 60%,rgba(0,212,255,.06),transparent 70%); }
.page-hero::after  { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad1); }
.page-hero-inner   { position:relative; z-index:2; }
.breadcrumb { display:flex; align-items:center; gap:8px; font-size:.8rem; color:var(--text3); margin-bottom:20px; }
.breadcrumb a { color:var(--text3); transition:color .2s; }
.breadcrumb a:hover { color:var(--cyan); }
.breadcrumb span { color:var(--border-dark2); }
.page-hero h1 { color:#fff; margin-bottom:18px; }
.page-hero p  { color:var(--text2); font-size:1.1rem; max-width:560px; }

/* ── White section ── */
.ws { background:var(--surface); }
.ws h2,
.ws h3,
.ws h4 { color:var(--ink); }
.ws p   { color:var(--ink2); }
.ws .label { color:var(--cyan); }

/* ── Light section ── */
.ls { background:var(--surface2); }
.ls h2,
.ls h3,
.ls h4 { color:var(--ink); }
.ls p   { color:var(--ink2); }
.ls .label { color:var(--cyan); }

/* ── White card ── */
.wcard {
  background:#fff; border:1px solid var(--border-light);
  border-radius:var(--rlg); padding:32px;
  box-shadow:var(--shadow);
  transition:all .3s; position:relative; overflow:hidden;
}
.wcard::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--grad1); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
.wcard:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:rgba(0,212,255,.2); }
.wcard:hover::before { transform:scaleX(1); }
.wcard h4 { color:var(--ink); margin-bottom:10px; }
.wcard p  { color:var(--ink2); font-size:.92rem; }
.wcard-icon { width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.2rem; margin-bottom:20px; }
.wcard-icon.c { background:rgba(0,212,255,.1); border:1px solid rgba(0,212,255,.2); }
.wcard-icon.g { background:rgba(0,229,160,.1); border:1px solid rgba(0,229,160,.2); }
.wcard-icon.a { background:rgba(255,179,64,.1); border:1px solid rgba(255,179,64,.2); }

/* ── Dark card ── */
.dcard {
  background:rgba(255,255,255,.04); border:1px solid var(--border-dark);
  border-radius:var(--rlg); padding:32px;
  transition:all .3s; position:relative; overflow:hidden;
}
.dcard::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad1); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
.dcard:hover { border-color:var(--border-dark2); background:rgba(255,255,255,.07); transform:translateY(-4px); box-shadow:0 20px 60px rgba(0,0,0,.4); }
.dcard:hover::before { transform:scaleX(1); }
.dcard h4 { color:#fff; margin-bottom:10px; }
.dcard p  { color:var(--text2); font-size:.92rem; }
.dcard-icon { width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.2rem; margin-bottom:20px; }
.dcard-icon.c { background:var(--cyan-dim); border:1px solid rgba(0,212,255,.2); }
.dcard-icon.g { background:var(--green-dim); border:1px solid rgba(0,229,160,.18); }
.dcard-icon.a { background:var(--amber-dim); border:1px solid rgba(255,179,64,.18); }

/* ── Service grid (white) ── */
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--border-light); border:1px solid var(--border-light); border-radius:var(--rxl); overflow:hidden; box-shadow:var(--shadow); }
.svc-item { background:#fff; padding:36px 28px; transition:background .3s; position:relative; overflow:hidden; }
.svc-item::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:var(--grad1); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
.svc-item:hover { background:var(--surface2); }
.svc-item:hover::after { transform:scaleX(1); }
.svc-num { font-size:.68rem; font-weight:700; letter-spacing:.16em; color:var(--cyan); text-transform:uppercase; margin-bottom:12px; }
.svc-item h3 { font-size:1rem; margin-bottom:10px; color:var(--ink); }
.svc-item p  { font-size:.88rem; color:var(--ink2); line-height:1.65; }
.ideal-tag { display:inline-flex; margin-top:14px; padding:5px 12px; background:var(--cyan-dim); border:1px solid rgba(0,212,255,.18); border-radius:50px; font-size:.74rem; color:var(--cyan); font-weight:500; }

/* ── CTA band dark ── */
.cta-dark { background:var(--bg2); border-top:1px solid var(--border-dark); padding:100px 0; text-align:center; position:relative; overflow:hidden; }
.cta-dark::before { content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:900px; height:500px; background:radial-gradient(ellipse,rgba(0,212,255,.07),transparent 70%); pointer-events:none; }
.cta-dark::after  { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad1); }
.cta-dark h2 { color:#fff; margin-bottom:16px; }
.cta-dark p  { color:var(--text2); font-size:1.05rem; max-width:520px; margin:0 auto 36px; }
.cta-btns    { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; position:relative; z-index:1; }

/* ── CTA band white ── */
.cta-white { background:#fff; border-top:1px solid var(--border-light); border-bottom:1px solid var(--border-light); padding:100px 0; text-align:center; position:relative; overflow:hidden; }
.cta-white::before { content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:900px; height:500px; background:radial-gradient(ellipse,rgba(0,212,255,.05),transparent 70%); pointer-events:none; }
.cta-white h2 { color:var(--ink); margin-bottom:16px; }
.cta-white p  { color:var(--ink2); font-size:1.05rem; max-width:520px; margin:0 auto 36px; }

/* ── Social proof (white) ── */
.sproof { background:#fff; border-top:1px solid var(--border-light); border-bottom:1px solid var(--border-light); padding:64px 0; text-align:center; }
.sp-label { color:var(--ink3); font-size:.75rem; letter-spacing:.12em; text-transform:uppercase; margin-bottom:32px; }
.lrow  { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; align-items:center; }
.lph   { padding:10px 22px; background:var(--surface2); border:1px solid var(--border-light); border-radius:8px; font-size:.72rem; font-weight:600; letter-spacing:.1em; color:var(--ink3); text-transform:uppercase; transition:all .2s; }
.lph:hover { border-color:rgba(0,212,255,.3); color:var(--ink); box-shadow:0 4px 16px rgba(0,212,255,.1); }

/* ── Footer ── */
.footer  { background:var(--bg); border-top:1px solid var(--border-dark); padding:64px 0 28px; }
.fg-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; margin-bottom:56px; }
.fb-logo { display:flex; align-items:center; gap:10px; font-family:var(--ff-head); font-size:1.2rem; font-weight:800; color:#fff; margin-bottom:14px; }
.fb p  { color:var(--text3); font-size:.88rem; max-width:260px; line-height:1.7; }
.fc h5 { font-size:.7rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--text3); margin-bottom:18px; }
.fc a  { display:block; color:var(--text2); font-size:.88rem; margin-bottom:10px; transition:color .2s; }
.fc a:hover { color:var(--cyan); }
.fbot  { border-top:1px solid var(--border-dark); padding-top:22px; display:flex; align-items:center; justify-content:space-between; }
.fbot p { color:var(--text3); font-size:.8rem; }

/* ── Tags ── */
.stags { display:flex; flex-wrap:wrap; gap:8px; margin-top:24px; }
.stag  { padding:6px 14px; border:1px solid var(--border-light); border-radius:50px; font-size:.82rem; color:var(--ink2); background:#fff; transition:all .2s; }
.stag:hover { background:var(--cyan-dim); border-color:rgba(0,212,255,.3); color:var(--ink); }

/* ── Reveal states ── */
.rev   { opacity:0; transform:translateY(36px); }
.rev-l { opacity:0; transform:translateX(-36px); }
.rev-r { opacity:0; transform:translateX(36px); }
.rev-s { opacity:0; transform:scale(.93); }

/* ── Responsive ── */
@media(max-width:1024px) {
  .svc-grid { grid-template-columns:1fr 1fr; }
  .fg-grid  { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
  .container { padding:0 20px; }
  .section   { padding:72px 0; }
  h1 { font-size:2.6rem; }
  h2 { font-size:2rem; }
  .svc-grid { grid-template-columns:1fr; }
  .nav-links, .nav-cta { display:none; }
  .nav-toggle { display:block; }
  .fg-grid  { grid-template-columns:1fr; }
  .fbot     { flex-direction:column; gap:10px; text-align:center; }
  .page-hero { padding:120px 0 60px; }
  body { cursor:auto; }
  #cursor-dot, #cursor-ring { display:none; }
}
