/* ==========================================================================
   TheloSite.gr - Isolated High-Specificity CSS (custom.css)
   Prepended with .ts-exclusive or body.ts-theme-body to bypass WHMCS Bootstrap.
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Typography & Global Resets
   -------------------------------------------------------------------------- */
body.ts-theme-body {
  font-family: 'Inter', sans-serif !important;
  background-color: #FFFFFF !important;
  color: #4B5563 !important;
  line-height: 1.6 !important;
  -webkit-font-smoothing: antialiased !important;
}

body.ts-theme-body h1,
body.ts-theme-body h2,
body.ts-theme-body h3,
body.ts-theme-body h4,
body.ts-theme-body h5,
body.ts-theme-body h6,
.ts-exclusive h1,
.ts-exclusive h2,
.ts-exclusive h3,
.ts-exclusive h4,
.ts-exclusive h5,
.ts-exclusive h6 {
  font-family: 'Playfair Display', serif !important;
  color: #111827 !important;
  font-weight: 500 !important;
  line-height: 1.25 !important;
}

body.ts-theme-body a,
.ts-exclusive a {
  text-decoration: none !important;
  color: inherit !important;
  transition: all 0.25s ease-in-out !important;
}

/* Accent Colors & General Variables */
.ts-exclusive .ts-cat-highlight {
  color: #B78A5C !important;
}

/* --------------------------------------------------------------------------
   2. Header & Navigation (body.ts-theme-body namespace)
   -------------------------------------------------------------------------- */
body.ts-theme-body .ts-navbar {
  background-color: #FFFFFF !important;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
  width: 100% !important;
}

body.ts-theme-body .ts-navbar-container {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  height: 80px !important;
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 0 24px !important;
  box-sizing: border-box !important;
}

body.ts-theme-body .ts-logo-box {
  display: flex !important;
  flex-direction: column !important;
}

body.ts-theme-body .ts-logo-title {
  font-family: 'Playfair Display', serif !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: #111827 !important;
}

body.ts-theme-body .ts-logo-title span {
  color: #C8A97E !important;
}

body.ts-theme-body .ts-logo-subtitle {
  font-family: 'Inter', sans-serif !important;
  font-size: 10px !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  color: #6B7280 !important;
  margin-top: -4px !important;
  align-self: flex-end !important;
}

body.ts-theme-body .ts-menu-nav {
  display: flex !important;
  align-items: center !important;
  gap: 30px !important;
}

body.ts-theme-body .ts-menu-item {
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  color: #1E293B !important;
  position: relative !important;
  padding: 8px 0 !important;
}

body.ts-theme-body .ts-menu-item:hover {
  color: #C8A97E !important;
}

/* Dropdown Menu styling */
body.ts-theme-body .ts-dropdown-wrapper {
  position: relative !important;
}

body.ts-theme-body .ts-dropdown-menu {
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  background-color: #FFFFFF !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
  border-radius: 8px !important;
  box-shadow: 0 20px 40px -10px rgba(15, 23, 42, 0.08) !important;
  min-width: 220px !important;
  padding: 10px 0 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transform: translateY(10px) !important;
  transition: all 0.25s ease-in-out !important;
  z-index: 1010 !important;
}

body.ts-theme-body .ts-dropdown-wrapper:hover .ts-dropdown-menu {
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateY(0) !important;
}

body.ts-theme-body .ts-dropdown-link {
  display: block !important;
  padding: 10px 20px !important;
  font-size: 14px !important;
  color: #1E293B !important;
  transition: all 0.25s ease-in-out !important;
}

body.ts-theme-body .ts-dropdown-link:hover {
  background-color: #F5F1EB !important;
  color: #B78A5C !important;
}

body.ts-theme-body .ts-navbar-btn {
  border: 1px solid #C8A97E !important;
  color: #B78A5C !important;
  background: transparent !important;
  padding: 10px 24px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  border-radius: 50px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  font-family: 'Inter', sans-serif !important;
  transition: all 0.2s ease-in-out !important;
}

body.ts-theme-body .ts-navbar-btn:hover {
  background-color: #B78A5C !important;
  color: #FFFFFF !important;
  border-color: #B78A5C !important;
}

/* --------------------------------------------------------------------------
   3. Isolated Content Styles (.ts-exclusive namespace)
   -------------------------------------------------------------------------- */
.ts-exclusive {
  box-sizing: border-box !important;
}

.ts-exclusive *, 
.ts-exclusive *::before, 
.ts-exclusive *::after {
  box-sizing: border-box !important;
}

.ts-exclusive .ts-container {
  width: 100% !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 40px !important;
  box-sizing: border-box !important;
}

.ts-exclusive .ts-section-spacing {
  padding: 90px 0 !important;
}

.ts-exclusive .ts-grid-3 {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 30px !important;
}

.ts-exclusive .ts-grid-2 {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 40px !important;
}

/* Isolated Buttons */
.ts-exclusive .ts-cat-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 12px 28px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.8px !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  transition: all 0.25s ease-in-out !important;
  text-decoration: none !important;
  border: 1px solid transparent !important;
}

.ts-exclusive .ts-cat-btn-solid {
  background-color: #B78A5C !important;
  color: #FFFFFF !important;
}

.ts-exclusive .ts-cat-btn-solid:hover {
  background-color: #A37649 !important;
  transform: translateY(-1px) !important;
}

.ts-exclusive .ts-cat-btn-outline {
  border-color: #C8A97E !important;
  color: #B78A5C !important;
  background: transparent !important;
}

.ts-exclusive .ts-cat-btn-outline:hover {
  background-color: #B78A5C !important;
  color: #FFFFFF !important;
  border-color: #B78A5C !important;
  transform: translateY(-1px) !important;
}

/* Isolated Section Headers */
.ts-exclusive .ts-cat-center-header {
  text-align: center !important;
  margin-bottom: 50px !important;
}

.ts-exclusive .ts-cat-center-header h2 {
  font-size: 28px !important;
  margin-bottom: 12px !important;
}

.ts-exclusive .ts-cat-center-header p {
  font-size: 15px !important;
  color: #6B7280 !important;
}

/* Hero Section */
.ts-exclusive .ts-hero-section {
  padding: 0 !important;
  background: radial-gradient(circle at top right, rgba(200, 169, 126, 0.08), transparent 45%) !important;
}

.ts-exclusive .ts-hero-flex {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 60px !important;
  padding: 80px 0 !important;
}

.ts-exclusive .ts-hero-left {
  flex: 1.2 !important;
  max-width: 650px !important;
}

.ts-exclusive .ts-hero-right {
  flex: 0.8 !important;
  max-width: 450px !important;
}

.ts-exclusive .ts-hero-left h1 {
  font-size: 44px !important;
  line-height: 1.2 !important;
  margin-bottom: 20px !important;
}

.ts-exclusive .ts-hero-left p {
  font-size: 16px !important;
  color: #4B5563 !important;
  margin-bottom: 35px !important;
  font-weight: 400 !important;
  line-height: 1.7 !important;
}

.ts-exclusive .ts-hero-btns {
  display: flex !important;
  gap: 15px !important;
}

.ts-exclusive .ts-hero-right {
  display: flex !important;
  justify-content: center !important;
}

.ts-exclusive .ts-cat-hero-image-container {
  width: 100% !important;
  max-width: 520px !important;
  border-radius: 4px !important;
  overflow: hidden !important;
  box-shadow: 0 15px 35px rgba(15, 23, 42, 0.05) !important;
  border: 1px solid #EAE6DF !important;
}

.ts-exclusive .ts-cat-hero-img {
  width: 100% !important;
  height: auto !important;
  display: block !important;
}

/* "Οι Υπηρεσίες μας" Section */
.ts-exclusive .ts-services-section {
  background-color: #FFFFFF !important;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08) !important;
}

.ts-exclusive .ts-service-card {
  padding: 40px 30px !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
  border-radius: 8px !important;
  background-color: #FFFFFF !important;
  transition: all 0.25s ease-in-out !important;
}

.ts-exclusive .ts-service-card:hover {
  border-color: #C8A97E !important;
  box-shadow: 0 15px 30px rgba(15, 23, 42, 0.04) !important;
}

.ts-exclusive .ts-cat-feature-icon {
  width: 48px !important;
  height: 48px !important;
  margin: 0 auto 20px auto !important;
  color: #C8A97E !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* "Τα Πακέτα μας" Section */
.ts-exclusive .ts-packages-section {
  background-color: #FAF8F5 !important;
}

.ts-exclusive .ts-pricing-grid-exact {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 25px !important;
  width: 100% !important;
}

.ts-exclusive .ts-category-card {
  max-width: 360px !important;
  margin: 0 auto !important;
  width: 100% !important;
}

/* Portfolio Preview Section */
.ts-exclusive .ts-portfolio-section {
  background-color: #FFFFFF !important;
}

.ts-exclusive .ts-work-card {
  position: relative !important;
  border-radius: 4px !important;
  overflow: hidden !important;
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.02) !important;
  aspect-ratio: 4 / 3 !important;
}

.ts-exclusive .ts-work-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: all 0.25s ease-in-out !important;
}

.ts-exclusive .ts-work-card:hover .ts-work-img {
  transform: scale(1.05) !important;
}

.ts-exclusive .ts-work-overlay {
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(to top, rgba(15, 23, 42, 0.85) 0%, rgba(15, 23, 42, 0.2) 65%, transparent 100%) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  padding: 24px !important;
  opacity: 0 !important;
  transition: all 0.25s ease-in-out !important;
}

.ts-exclusive .ts-work-card:hover .ts-work-overlay {
  opacity: 1 !important;
}

.ts-exclusive .ts-work-overlay h3 {
  color: #FFFFFF !important;
  font-size: 18px !important;
  margin-bottom: 5px !important;
}

.ts-exclusive .ts-work-overlay span {
  color: #C8A97E !important;
  font-size: 13px !important;
  font-weight: 500 !important;
}

/* FAQ & Contact Split Section */
.ts-exclusive .ts-faq-section {
  background-color: #FAF8F5 !important;
  border-top: 1px solid rgba(15, 23, 42, 0.08) !important;
}

.ts-exclusive .ts-faq-split-layout {
  display: flex !important;
  gap: 50px !important;
  width: 100% !important;
}

.ts-exclusive .ts-faq-left-side {
  flex: 1.3 !important;
}

.ts-exclusive .ts-faq-right-side {
  flex: 0.7 !important;
  max-width: 380px !important;
}

.ts-exclusive .ts-faq-left-side h2 {
  font-size: 26px !important;
  margin-bottom: 30px !important;
}

.ts-exclusive .ts-cat-acc-bar {
  background-color: #FAF8F5 !important;
  border: 1px solid #EAE6DF !important;
  border-radius: 4px !important;
  margin-bottom: 12px !important;
  overflow: hidden !important;
  transition: all 0.2s ease !important;
}

.ts-exclusive .ts-cat-acc-btn {
  width: 100% !important;
  padding: 18px 20px !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  background: none !important;
  border: none !important;
  text-align: left !important;
  cursor: pointer !important;
}

.ts-exclusive .ts-cat-acc-btn h3 {
  font-family: 'Inter', sans-serif !important;
  font-size: 14.5px !important;
  font-weight: 600 !important;
  color: #111827 !important;
  margin: 0 !important;
}

.ts-exclusive .ts-cat-acc-arrow {
  font-size: 10px !important;
  color: #B78A5C !important;
  transition: transform 0.25s ease !important;
}

.ts-exclusive .ts-cat-acc-panel {
  max-height: 0 !important;
  overflow: hidden !important;
  transition: max-height 0.25s ease-out !important;
  background-color: #FFFFFF !important;
}

.ts-exclusive .ts-cat-acc-inner {
  padding: 0 20px 18px 20px !important;
  font-size: 13.5px !important;
  color: #4B5563 !important;
  line-height: 1.6 !important;
}

.ts-exclusive .ts-cat-acc-bar.active {
  border-color: #C8A97E !important;
  background-color: #FFFFFF !important;
}

.ts-exclusive .ts-cat-acc-bar.active .ts-cat-acc-arrow {
  transform: rotate(180deg) !important;
}

.ts-exclusive .ts-cat-info-card {
  background: #FFFFFF !important;
  border: 1px solid #EAE6DF !important;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.02) !important;
  border-radius: 6px !important;
  padding: 40px !important;
  text-align: center !important;
  align-self: flex-start !important;
}

.ts-exclusive .ts-cat-info-card h3 {
  font-family: 'Playfair Display', serif !important;
  font-size: 22px !important;
  margin-bottom: 12px !important;
}

.ts-exclusive .ts-cat-info-card p {
  font-size: 14px !important;
  color: #6B7280 !important;
  margin-bottom: 25px !important;
  line-height: 1.6 !important;
}

.ts-exclusive .ts-cat-info-card .ts-cat-btn {
  width: 100% !important;
  max-width: 200px !important;
}

/* --------------------------------------------------------------------------
   4. Footer Styling (body.ts-theme-body namespace)
   -------------------------------------------------------------------------- */
body.ts-theme-body .ts-footer {
  background-color: #FAF8F5 !important;
  color: #4B5563 !important;
  padding: 80px 0 30px 0 !important;
  font-size: 14px !important;
  border-top: 1px solid #EAE6DF !important;
}

body.ts-theme-body .ts-footer-grid {
  display: grid !important;
  grid-template-columns: 1.5fr 1fr 1fr 1fr !important;
  gap: 40px !important;
  margin-bottom: 60px !important;
  max-width: 1100px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 0 24px !important;
}

body.ts-theme-body .ts-footer-col h4 {
  color: #111827 !important;
  font-size: 16px !important;
  margin-bottom: 25px !important;
  position: relative !important;
  font-family: 'Inter', sans-serif !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

body.ts-theme-body .ts-footer-col h4::after {
  content: '' !important;
  display: block !important;
  width: 25px !important;
  height: 2px !important;
  background-color: #C8A97E !important;
  margin-top: 8px !important;
}

body.ts-theme-body .ts-footer-links {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

body.ts-theme-body .ts-footer-links a:hover {
  color: #C8A97E !important;
  padding-left: 4px !important;
}

body.ts-theme-body .ts-footer-brand p {
  line-height: 1.6 !important;
  margin-bottom: 25px !important;
}

body.ts-theme-body .ts-footer-socials {
  display: flex !important;
  gap: 10px !important;
}

body.ts-theme-body .ts-footer-social-link {
  width: 38px !important;
  height: 38px !important;
  background-color: #F5F1EB !important;
  border: 1px solid #EAE6DF !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #B78A5C !important;
  transition: all 0.25s ease-in-out !important;
}

body.ts-theme-body .ts-footer-social-link:hover {
  background-color: #B78A5C !important;
  color: #FFFFFF !important;
  transform: translateY(-2px) !important;
}

body.ts-theme-body .ts-footer-bottom {
  border-top: 1px solid #EAE6DF !important;
  padding-top: 30px !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  font-size: 12px !important;
  color: #6B7280 !important;
  max-width: 1100px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}

/* --------------------------------------------------------------------------
   5. Responsive Adapters
   -------------------------------------------------------------------------- */
@media (max-width: 991px) {
  .ts-exclusive .ts-grid-3, 
  .ts-exclusive .ts-grid-2,
  .ts-exclusive .ts-hero-grid,
  .ts-exclusive .ts-cat-split-grid {
    grid-template-columns: 1fr !important;
    gap: 45px !important;
  }
  .ts-exclusive .ts-hero-left {
    text-align: center !important;
  }
  .ts-exclusive .ts-hero-btns {
    justify-content: center !important;
  }
  body.ts-theme-body .ts-menu-nav {
    display: none !important;
  }
  body.ts-theme-body .ts-footer-grid {
    grid-template-columns: 1fr 1fr !important;
  }
}

@media (max-width: 768px) {
  body.ts-theme-body .ts-footer-grid {
    grid-template-columns: 1fr !important;
  }
  body.ts-theme-body .ts-footer-bottom {
    flex-direction: column !important;
    gap: 15px !important;
    text-align: center !important;
  }
}
