/* assets/css/global.css — Navbar + Footer only */

:root {
  --tn-orange:    #e8720c;
  --tn-green:     #5cb93c;
  --tn-dark:      #0e0e0e;
  --tn-nav-h:     68px;
  --green:        #2b9348;
  --green-light:  #52b788;
  --green-bg:     #f0f7f1;
  --dark-footer2: #162019;
  --border:       #e5e5e5;
  --muted:        #666;
}

html { overflow-x: hidden; scroll-behavior: smooth; }
body { overflow-x: hidden; }

/* ══════════════════════════════════════════════════
   NAVBAR
══════════════════════════════════════════════════ */
#mainNav {
  position: fixed;
  top: 0; left: 0;
  width: 100%;
  z-index: 9999;
  height: var(--tn-nav-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 36px;
  background: rgba(14,14,14,0.97);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition: background .3s, box-shadow .3s;
  flex-wrap: nowrap;
  border: none;
  border-radius: 0;
}
#mainNav.tn-scrolled {
  background: rgba(14,14,14,0.97);
  box-shadow: 0 2px 24px rgba(0,0,0,.5);
}

/* Logo */
.tn-nav-logo {
  font-family: 'Montserrat', sans-serif;
  font-weight: 900; font-size: 1.3rem;
  color: #fff !important;
  letter-spacing: -.02em;
  text-decoration: none !important;
  flex-shrink: 0; white-space: nowrap;
}
.tn-nav-logo span { color: var(--tn-orange); }

/* Desktop nav links */
#navLinks {
  display: flex;
  align-items: center;
  gap: 28px;
  list-style: none;
  margin: 0; padding: 0;
  flex-shrink: 0;
}
#navLinks li { margin: 0; padding: 0; }
#navLinks a {
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px; font-weight: 700;
  letter-spacing: .07em; text-transform: uppercase;
  color: rgba(255,255,255,.7) !important;
  text-decoration: none !important;
  position: relative; padding-bottom: 3px;
  transition: color .2s; white-space: nowrap;
}
#navLinks a::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0; right: 0;
  height: 2px; background: var(--tn-orange);
  transform: scaleX(0); transform-origin: left;
  transition: transform .25s cubic-bezier(.34,1.56,.64,1);
}
#navLinks a:hover,
#navLinks a.active { color: #fff !important; }
#navLinks a:hover::after,
#navLinks a.active::after { transform: scaleX(1); }

/* Right side */
.tn-nav-right {
  display: flex; align-items: center;
  gap: 16px; flex-shrink: 0;
}
.tn-nav-phone {
  display: flex; align-items: center; gap: 6px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px; font-weight: 600;
  color: rgba(255,255,255,.7) !important;
  text-decoration: none !important;
  white-space: nowrap; transition: color .2s;
}
.tn-nav-phone:hover { color: #fff !important; }

.tn-btn-nav {
  display: inline-block;
  background: var(--tn-green); color: #fff !important;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  padding: 10px 18px; text-decoration: none !important;
  border: none; cursor: pointer;
  white-space: nowrap; border-radius: 4px;
  transition: background .2s;
}
.tn-btn-nav:hover { background: #4aa82f; }

/* Hamburger — hidden on desktop */
#navToggle {
  display: none;
  flex-direction: column;
  justify-content: space-between;
  width: 28px; height: 20px;
  background: transparent; border: none;
  padding: 0; cursor: pointer;
  flex-shrink: 0; z-index: 10001;
}
#navToggle span {
  display: block; width: 100%; height: 2px;
  background: #fff; border-radius: 2px;
  transition: transform .3s, opacity .2s, width .2s;
  transform-origin: center;
}
#navToggle.open span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
#navToggle.open span:nth-child(2) { opacity: 0; width: 0; }
#navToggle.open span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }

/* Overlay */
#navOverlay {
  display: none;
  position: fixed; inset: 0;
  z-index: 9998;
  background: rgba(0,0,0,.65);
  opacity: 0; transition: opacity .3s;
  pointer-events: none;
}
#navOverlay.open { opacity: 1; pointer-events: auto; }

/* Page body offset */
.tn-page-wrap { padding-top: var(--tn-nav-h); }

/* ══════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════ */
.tn-footer { background: var(--dark-footer2); font-family: 'Inter', sans-serif; }
.tn-footer-top { padding: 64px 0 48px; }

.tn-footer-logo {
  font-family: 'Montserrat', sans-serif;
  font-weight: 900; font-size: 1.3rem;
  color: #fff; letter-spacing: -.02em; margin-bottom: 12px;
}
.tn-footer-logo span { color: var(--green-light); }
.tn-footer-tagline { font-size:.84rem; color:rgba(255,255,255,.45); line-height:1.7; max-width:240px; margin-bottom:8px; }
.tn-footer-reg { font-size:.72rem; color:rgba(255,255,255,.2); margin-bottom:18px; }
.tn-footer-social { display:flex; gap:8px; flex-wrap:wrap; }
.tn-footer-social a {
  width:34px; height:34px; border-radius:50%;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.45); font-size:.88rem;
  text-decoration:none; transition:all .2s;
}
.tn-footer-social a:hover { background:var(--green); border-color:var(--green); color:#fff; }
.tn-footer-col-title { font-size:.69rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.28); margin-bottom:18px; }
.tn-footer-links { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:9px; }
.tn-footer-links a { font-size:.84rem; color:rgba(255,255,255,.5); text-decoration:none; transition:color .2s,padding-left .2s; display:inline-block; }
.tn-footer-links a:hover { color:var(--green-light); padding-left:3px; }
.tn-footer-contact { list-style:none; padding:0; margin:0 0 18px; display:flex; flex-direction:column; }
.tn-footer-contact li { display:flex; align-items:flex-start; gap:10px; padding:10px 0; border-bottom:1px solid rgba(255,255,255,.06); font-size:.84rem; color:rgba(255,255,255,.5); }
.tn-footer-contact li:last-child { border-bottom:none; }
.tn-footer-contact li i { color:var(--green-light); font-size:.95rem; flex-shrink:0; margin-top:2px; width:16px; }
.tn-footer-contact li a { color:rgba(255,255,255,.5); text-decoration:none; transition:color .2s; }
.tn-footer-contact li a:hover { color:var(--green-light); }
.tn-footer-cta { display:inline-block; background:var(--green); color:#fff; font-size:.78rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:10px 18px; border-radius:5px; text-decoration:none; transition:background .2s; }
.tn-footer-cta:hover { background:#1e6b33; color:#fff; }
.tn-footer-bottom { border-top:1px solid rgba(255,255,255,.07); padding:18px 0; }
.tn-footer-bottom p { font-size:.77rem; color:rgba(255,255,255,.25); margin:0; }
.tn-footer-bottom a { font-size:.77rem; color:rgba(255,255,255,.25); text-decoration:none; transition:color .2s; }
.tn-footer-bottom a:hover { color:rgba(255,255,255,.6); }
.tn-footer-bottom span { color:rgba(255,255,255,.12); margin:0 6px; }

/* ══════════════════════════════════════════════════
   RESPONSIVE — hide phone number on tablet
══════════════════════════════════════════════════ */
@media (max-width: 991px) {
  .tn-nav-phone { display: none !important; }
}

/* ══════════════════════════════════════════════════
   MOBILE NAVBAR (≤ 767px)
══════════════════════════════════════════════════ */
@media (max-width: 767px) {

  #mainNav {
    padding: 0 20px;
    height: 60px;
  }
  .tn-page-wrap { padding-top: 60px; }

  /* Show hamburger button */
  #navToggle { display: flex !important; }

  /* Hide phone + CTA on mobile */
  .tn-nav-phone { display: none !important; }
  .tn-btn-nav   { display: none !important; }

  /* Activate overlay */
  #navOverlay { display: block; }

  /* ── DRAWER ────────────────────────────────────────── */
  #navLinks {
    /* Position: fixed panel on right edge, off-screen by default */
    position: fixed !important;
    top: 0 !important;
    right: -100% !important;
    bottom: 0 !important;
    left: auto !important;
    width: 280px !important;
    max-width: 85vw !important;
    height: 100% !important;
    height: 100dvh !important;

    /* Stacking */
    z-index: 9999 !important;

    /* Appearance */
    background: #111111 !important;
    border-left: 1px solid rgba(255,255,255,.08) !important;
    box-shadow: -10px 0 40px rgba(0,0,0,.6) !important;

    /* Layout — vertical list */
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 0 !important;

    /* Spacing inside */
    padding-top: 72px !important;
    padding-bottom: 40px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;

    /* Scroll */
    overflow-y: auto !important;
    overflow-x: hidden !important;

    /* Slide animation */
    transition: right .32s cubic-bezier(.4,0,.2,1) !important;

    /* Reset any desktop margin that could hide items */
    margin: 0 !important;
  }

  /* Open state */
  #navLinks.open { right: 0 !important; }

  /* List items — full width rows */
  #navLinks li {
    width: 100% !important;
    display: block !important;
    border-bottom: 1px solid rgba(255,255,255,.07) !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  /* Anchor tags — large tap targets */
  #navLinks a {
    display: block !important;
    width: 100% !important;
    padding: 18px 28px !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    color: rgba(255,255,255,.6) !important;
    text-decoration: none !important;
    transition: color .2s, background .2s !important;
    white-space: nowrap !important;
  }
  #navLinks a::after { display: none !important; }

  #navLinks a:hover,
  #navLinks a.active {
    color: var(--tn-orange) !important;
    background: rgba(255,255,255,.05) !important;
  }

  /* CTA button pinned at bottom of drawer */
  #navLinks::after {
    content: 'Start a Project →';
    display: block;
    margin: 28px 24px 0;
    padding: 14px 20px;
    background: var(--tn-green);
    color: #fff;
    font-family: 'Montserrat', sans-serif;
    font-size: 11px; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase;
    border-radius: 4px; text-align: center;
    flex-shrink: 0;
  }

  /* Footer adjustments */
  .tn-footer-top { padding: 48px 0 32px; }
}

/* Very small screens */
@media (max-width: 400px) {
  #mainNav { padding: 0 16px; }
  .tn-nav-logo { font-size: 1.1rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
}