/* ============================================================
   AffilX TechOps — main-service category pages (shared theme)
   teal #357974 · dark #17413b / #0d2b27 · gold #ffaa21 · orange #f97316
   ============================================================ */
:root{
  --ts-teal:#357974; --ts-dark:#17413b; --ts-darker:#0d2b27;
  --ts-gold:#ffaa21; --ts-orange:#f97316; --ts-slate:#5a6c68;
}
.ts-main, .ts-main p, .ts-main a, .ts-main span, .ts-main li, .ts-main button{
  font-family:'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
}
.ts-main h1, .ts-main h2, .ts-main h3, .ts-main h4{
  font-family:'Inter', system-ui, sans-serif; letter-spacing:-.02em;
}

/* chips */
.ts-chip{ display:inline-flex; align-items:center; gap:8px; font-family:'Courier New',ui-monospace,monospace;
  font-size:.74rem; font-weight:700; letter-spacing:1.4px; text-transform:uppercase; padding:7px 15px; border-radius:30px; }
.ts-chip.dark{ color:#ffd27a; background:rgba(255,170,33,.12); border:1px solid rgba(255,170,33,.4); }
.ts-chip.light{ color:var(--ts-teal); background:#eaf3f1; border:1px solid #cfe3df; }

/* ---------- HERO ---------- */
.ts-hero{ position:relative; min-height:66vh; display:flex; align-items:center; padding:90px 20px; overflow:hidden;
  background:url('../img/service/tech-hero.jpg') center/cover no-repeat; }
.ts-hero::before{ content:''; position:absolute; inset:0;
  background:linear-gradient(115deg, rgba(8,32,29,.93) 0%, rgba(23,65,59,.82) 48%, rgba(53,121,116,.5) 100%); }
.ts-hero::after{ content:''; position:absolute; inset:0; pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:46px 46px; -webkit-mask-image:linear-gradient(90deg,#000,transparent 72%); mask-image:linear-gradient(90deg,#000,transparent 72%); }
.ts-hero-inner{ position:relative; z-index:2; max-width:1180px; margin:0 auto; width:100%; display:grid; grid-template-columns:1.4fr .92fr; gap:46px; align-items:center; }
.ts-hero-content{ min-width:0; }
.ts-breadcrumb{ font-size:13px; color:rgba(255,255,255,.6); margin-bottom:18px; }
.ts-breadcrumb a{ color:rgba(255,255,255,.75); text-decoration:none; }
.ts-breadcrumb a:hover{ color:var(--ts-gold); }
.ts-hero h1{ font-size:46px; font-weight:800; color:#fff; line-height:1.1; max-width:840px; margin:14px 0 18px; }
.ts-hero h1 .gold{ color:var(--ts-gold); }
.ts-hero .lead{ font-size:17px; line-height:1.7; color:rgba(255,255,255,.75); max-width:640px; margin-bottom:30px; }
.ts-actions{ display:flex; gap:14px; flex-wrap:wrap; }
.ts-btn{ display:inline-flex; align-items:center; gap:8px; font-size:14px; font-weight:600; letter-spacing:.5px;
  text-transform:uppercase; padding:13px 26px; border-radius:50px 50px 50px 0; text-decoration:none; transition:.25s; cursor:pointer; }
.ts-btn.solid{ background:var(--ts-gold); color:var(--ts-dark); border:1px solid var(--ts-gold); }
.ts-btn.solid:hover{ background:#ffba47; }
.ts-btn.ghost{ background:transparent; color:#fff; border:1px solid rgba(255,255,255,.35); }
.ts-btn.ghost:hover{ background:rgba(255,255,255,.12); border-color:#fff; }

/* hero enquiry form (right side) */
.ts-hero-form{ background:#fff; border-radius:16px; padding:26px 24px; box-shadow:0 22px 50px rgba(8,32,29,.30); }
.ts-hero-form h3{ font-size:19px; font-weight:700; color:var(--ts-dark); text-align:center; margin-bottom:16px; }
.ts-hero-form input, .ts-hero-form textarea, .ts-hero-form select{
  width:100%; margin-bottom:12px; padding:11px 12px; border:1px solid #d9e2e0; border-radius:8px;
  font-size:14px; font-family:'Inter', system-ui, sans-serif; color:#17413b; background:#fff;
}
.ts-hero-form input:focus, .ts-hero-form textarea:focus, .ts-hero-form select:focus{ outline:none; border-color:var(--ts-teal); }
.ts-hero-form textarea{ resize:vertical; }
.ts-form-phone{ display:flex; gap:8px; }
.ts-form-phone select{ flex:0 0 82px; }
.ts-form-phone input{ flex:1; }
.ts-hero-form button{
  width:100%; background:var(--ts-teal); color:#fff; border:none; padding:12px; border-radius:8px;
  font-weight:600; font-size:14px; letter-spacing:.6px; cursor:pointer; transition:background .2s;
}
.ts-hero-form button:hover{ background:#2c6760; }

@media (max-width:900px){
  .ts-hero-inner{ grid-template-columns:1fr; gap:32px; }
  .ts-hero-form{ max-width:460px; }
}

/* ---------- generic section + heading ---------- */
.ts-section{ padding:80px 20px; }
.ts-wrap{ max-width:1180px; margin:0 auto; }
.ts-head{ text-align:center; max-width:700px; margin:0 auto 48px; }
.ts-head h2{ font-size:34px; font-weight:700; color:var(--ts-dark); margin:14px 0 12px; }
.ts-head h2 span{ color:var(--ts-teal); }
.ts-head p{ font-size:16px; color:var(--ts-slate); line-height:1.7; }

/* ---------- ABOUT ---------- */
.ts-about{ background:#fff; }
.ts-about-inner{ display:grid; grid-template-columns:1.1fr 1fr; gap:50px; align-items:center; max-width:1180px; margin:0 auto; }
.ts-about-text h2{ font-size:32px; font-weight:700; color:var(--ts-dark); margin:14px 0 16px; }
.ts-about-text h2 span{ color:var(--ts-teal); }
.ts-about-text p{ font-size:16px; color:var(--ts-slate); line-height:1.8; margin-bottom:14px; }
.ts-about-img img{ width:100%; border-radius:18px; box-shadow:0 18px 44px rgba(8,32,29,.18); }
.ts-feature-list{ list-style:none; padding:0; margin:18px 0 0; display:flex; flex-wrap:wrap; gap:10px 22px; }
.ts-feature-list li{ display:flex; align-items:center; gap:9px; font-size:.95rem; color:var(--ts-dark); font-weight:500; }
.ts-feature-list i{ color:#fff; background:var(--ts-teal); width:22px; height:22px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.7rem; }

/* ---------- WHY (reasons) ---------- */
.ts-why{ background:#f4f8f7; }
.ts-why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; max-width:1180px; margin:0 auto; }
.ts-why-card{ background:#fff; border:1px solid #eef2f1; border-radius:16px; padding:34px 26px; text-align:center; transition:transform .3s, box-shadow .3s; }
.ts-why-card:hover{ transform:translateY(-6px); box-shadow:0 14px 32px rgba(0,0,0,.08); }
.ts-why-ic{ width:64px; height:64px; border-radius:50%; margin:0 auto 18px; display:flex; align-items:center; justify-content:center; background:#fff4e0; color:var(--ts-gold); font-size:1.5rem; }
.ts-why-card h4{ font-size:1.1rem; font-weight:700; color:var(--ts-dark); margin-bottom:10px; }
.ts-why-card p{ font-size:.93rem; color:var(--ts-slate); line-height:1.6; margin:0; }

/* ---------- SUB-SERVICES ---------- */
.ts-services{ background:#fff; }
.ts-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; max-width:1180px; margin:0 auto; }
.ts-card{ position:relative; overflow:hidden; background:#fff; border:1px solid #e7efed; border-radius:16px; padding:28px 24px; transition:transform .32s, box-shadow .32s, background .32s, border-color .32s; }
.ts-card::before{ content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--ts-teal),var(--ts-gold)); transform:scaleX(0); transform-origin:left; transition:transform .35s; }
.ts-card:hover{ transform:translateY(-6px); box-shadow:0 16px 38px rgba(53,121,116,.18); background:var(--ts-dark); border-color:transparent; }
.ts-card:hover::before{ transform:scaleX(1); }
.ts-card-ic{ width:56px; height:56px; border-radius:14px; display:flex; align-items:center; justify-content:center; background:#eaf3f1; color:var(--ts-teal); font-size:1.5rem; margin-bottom:18px; transition:.3s; }
.ts-card:hover .ts-card-ic{ background:rgba(255,170,33,.16); color:var(--ts-gold); }
.ts-card h3{ font-size:1.08rem; font-weight:700; color:var(--ts-dark); margin-bottom:10px; transition:.3s; }
.ts-card:hover h3{ color:#fff; }
.ts-card p{ font-size:.92rem; color:var(--ts-slate); line-height:1.6; margin:0; transition:.3s; }
.ts-card:hover p{ color:rgba(255,255,255,.72); }
.ts-tags{ display:flex; flex-wrap:wrap; gap:6px; margin-top:16px; }
.ts-tags span{ font-size:11px; font-weight:500; background:#eef3f1; color:var(--ts-slate); padding:4px 10px; border-radius:6px; transition:.3s; }
.ts-card:hover .ts-tags span{ background:rgba(255,255,255,.1); color:rgba(255,255,255,.75); }

/* ---------- CTA ---------- */
.ts-cta{ position:relative; overflow:hidden; background:var(--ts-teal); padding:80px 20px; text-align:center; }
.ts-cta::before{ content:''; position:absolute; inset:0; pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:40px 40px; -webkit-mask-image:radial-gradient(ellipse at center,#000 22%,transparent 80%); mask-image:radial-gradient(ellipse at center,#000 22%,transparent 80%); }
.ts-cta-inner{ position:relative; z-index:1; max-width:680px; margin:0 auto; }
.ts-cta h2{ color:#fff; font-size:2.1rem; font-weight:700; margin-bottom:14px; }
.ts-cta h2 span{ color:var(--ts-gold); }
.ts-cta p{ color:#dbe8e4; font-size:1.05rem; margin-bottom:28px; }

/* ---------- responsive ---------- */
@media (max-width:992px){
  .ts-why-grid, .ts-grid{ grid-template-columns:repeat(2,1fr); }
  .ts-about-inner{ grid-template-columns:1fr; gap:32px; }
}
@media (max-width:768px){
  .ts-hero h1{ font-size:32px; }
  .ts-section{ padding:60px 20px; }
  .ts-head h2, .ts-about-text h2{ font-size:26px; }
}
@media (max-width:600px){
  .ts-why-grid, .ts-grid{ grid-template-columns:1fr; }
}

/* ============================================================
   WHY — split: sticky heading panel (left) + reason rows (right)
   ============================================================ */
.ts-why-split{ display:grid; grid-template-columns:.82fr 1.4fr; gap:44px; max-width:1180px; margin:0 auto; align-items:start; }
.ts-why-aside{ position:sticky; top:100px; }
.ts-why-aside h2{ font-size:32px; font-weight:700; color:var(--ts-dark); margin:14px 0 14px; line-height:1.2; }
.ts-why-aside h2 span{ color:var(--ts-teal); }
.ts-why-aside p{ font-size:16px; color:var(--ts-slate); line-height:1.75; margin-bottom:22px; }
.ts-why-list{ display:flex; flex-direction:column; gap:14px; }
.ts-why-row{ display:flex; gap:18px; align-items:flex-start; background:#fff; border:1px solid #e7efed; border-radius:14px; padding:22px 24px; transition:transform .25s, box-shadow .25s, border-color .25s; }
.ts-why-row:hover{ transform:translateX(5px); box-shadow:0 12px 28px rgba(53,121,116,.10); border-color:var(--ts-teal); }
.ts-why-row .ts-why-ic{ margin-bottom:0; flex:0 0 auto; }
.ts-why-row h4{ font-size:1.05rem; font-weight:700; color:var(--ts-dark); margin-bottom:6px; }
.ts-why-row p{ font-size:.92rem; color:var(--ts-slate); line-height:1.6; margin:0; }
@media (max-width:992px){
  .ts-why-split{ grid-template-columns:1fr; gap:28px; }
  .ts-why-aside{ position:static; }
}

/* ============================================================
   SUB-SERVICES — accordion list
   ============================================================ */
.ts-acc{ max-width:940px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.ts-acc-item{ background:#fff; border:1px solid #e7efed; border-radius:14px; overflow:hidden; transition:border-color .3s, box-shadow .3s; }
.ts-acc-item.open{ border-color:var(--ts-teal); box-shadow:0 14px 32px rgba(53,121,116,.12); }
.ts-acc-head{ width:100%; display:flex; align-items:center; gap:16px; padding:20px 22px; background:none; border:none; cursor:pointer; text-align:left; font-family:inherit; }
.ts-acc-ic{ width:46px; height:46px; flex:0 0 auto; border-radius:12px; display:flex; align-items:center; justify-content:center; background:#eaf3f1; color:var(--ts-teal); font-size:1.2rem; transition:.3s; }
.ts-acc-item.open .ts-acc-ic{ background:var(--ts-teal); color:#fff; }
.ts-acc-title{ flex:1; font-size:1.08rem; font-weight:700; color:var(--ts-dark); }
.ts-acc-chev{ flex:0 0 auto; color:var(--ts-slate); transition:transform .35s, color .3s; }
.ts-acc-item.open .ts-acc-chev{ transform:rotate(180deg); color:var(--ts-teal); }
.ts-acc-body{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .35s ease; }
.ts-acc-item.open .ts-acc-body{ grid-template-rows:1fr; }
.ts-acc-body-inner{ overflow:hidden; }
.ts-acc-body-inner .pad{ padding:0 22px 22px 84px; }
.ts-acc-body-inner p{ font-size:.95rem; color:var(--ts-slate); line-height:1.65; margin:0 0 12px; }
@media (max-width:600px){
  .ts-acc-head{ padding:16px 18px; gap:12px; }
  .ts-acc-body-inner .pad{ padding:0 18px 20px 18px; }
}

/* ============================================================
   DATA-FLOW DIAGRAM — multi-tool integration -> MIS
   ============================================================ */
.ts-flow{ background:#f4f8f7; }
.ts-flow-row{ display:flex; align-items:stretch; justify-content:center; max-width:1180px; margin:0 auto; }
.ts-flow-stage{ flex:1 1 0; min-width:0; background:#fff; border:1px solid #e7efed; border-radius:16px; padding:26px 20px; text-align:center; transition:transform .3s, box-shadow .3s, border-color .3s; }
.ts-flow-stage:hover{ transform:translateY(-5px); box-shadow:0 16px 34px rgba(53,121,116,.12); border-color:var(--ts-teal); }
.ts-flow-ic{ width:60px; height:60px; border-radius:16px; margin:0 auto 14px; display:flex; align-items:center; justify-content:center; background:#eaf3f1; color:var(--ts-teal); font-size:1.6rem; }
.ts-flow-stage:nth-child(7) .ts-flow-ic{ background:#fff4e0; color:var(--ts-gold); }
.ts-flow-step{ font-family:'Courier New',ui-monospace,monospace; font-size:.7rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--ts-gold); margin-bottom:6px; }
.ts-flow-stage h4{ font-size:1.02rem; font-weight:700; color:var(--ts-dark); margin-bottom:8px; }
.ts-flow-stage p{ font-size:.86rem; color:var(--ts-slate); line-height:1.55; margin:0; }
.ts-flow-chips{ display:flex; flex-wrap:wrap; gap:6px; justify-content:center; margin-top:14px; }
.ts-flow-chips span{ font-size:11px; font-weight:600; background:#eef3f1; color:var(--ts-teal); padding:4px 9px; border-radius:6px; }
.ts-flow-arrow{ flex:0 0 auto; display:flex; align-items:center; justify-content:center; color:var(--ts-gold); font-size:1.3rem; padding:0 8px; }
@media (max-width:860px){
  .ts-flow-row{ flex-direction:column; align-items:center; gap:6px; }
  .ts-flow-stage{ width:100%; max-width:430px; flex:none; }
  .ts-flow-arrow{ transform:rotate(90deg); padding:8px 0; }
}

/* ============================================================
   MIS REPORTS — icon cards (what reports you get)
   ============================================================ */
.ts-reports{ background:#fff; }
.ts-reports-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; max-width:1180px; margin:0 auto; }
.ts-report{ display:flex; gap:14px; align-items:center; background:#fff; border:1px solid #e7efed; border-radius:14px; padding:18px; transition:transform .25s, box-shadow .25s, border-color .25s; }
.ts-report:hover{ transform:translateY(-4px); box-shadow:0 14px 30px rgba(53,121,116,.12); border-color:var(--ts-teal); }
.ts-report-ic{ flex:0 0 auto; width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; background:#eaf3f1; color:var(--ts-teal); font-size:1.25rem; }
.ts-report h4{ font-size:.97rem; font-weight:700; color:var(--ts-dark); margin:0 0 3px; }
.ts-report span{ font-size:.8rem; color:var(--ts-slate); }
@media (max-width:992px){ .ts-reports-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .ts-reports-grid{ grid-template-columns:1fr; } }

/* ============================================================
   DECISIONS — dark band: what decisions clients can make
   ============================================================ */
.ts-decisions{ position:relative; overflow:hidden; background:linear-gradient(150deg,#17413b 0%,#0d2b27 100%); }
.ts-decisions::before{ content:''; position:absolute; inset:0; pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:40px 40px; -webkit-mask-image:radial-gradient(ellipse at center,#000 22%,transparent 80%); mask-image:radial-gradient(ellipse at center,#000 22%,transparent 80%); }
.ts-decisions .ts-wrap{ position:relative; z-index:1; }
.ts-decisions .ts-head h2{ color:#fff; }
.ts-decisions .ts-head h2 span{ color:var(--ts-gold); }
.ts-decisions .ts-head p{ color:#cfe0dc; }
.ts-dec-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; max-width:1040px; margin:0 auto; }
.ts-dec{ display:flex; gap:16px; align-items:flex-start; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:14px; padding:22px 24px; transition:background .25s, border-color .25s, transform .25s; }
.ts-dec:hover{ background:rgba(255,255,255,.08); border-color:rgba(255,170,33,.4); transform:translateY(-3px); }
.ts-dec-ic{ flex:0 0 auto; width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; background:rgba(255,170,33,.15); color:var(--ts-gold); font-size:1.1rem; }
.ts-dec h4{ font-size:1rem; font-weight:700; color:#fff; margin:0 0 5px; }
.ts-dec p{ font-size:.88rem; color:rgba(255,255,255,.62); line-height:1.55; margin:0; }
@media (max-width:760px){ .ts-dec-grid{ grid-template-columns:1fr; } }
