/* ============================================================
   Tech Station Limited — front-end styles (loaded on Astra)
   Navy ink · teal-cyan accent · IBM Plex + Sora type
   Scoped under .ts-page for page content; header/footer/Woo
   overrides target Astra with high specificity.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@600;700;800&family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  --ts-ink:#0A0F1A; --ts-ink-2:#0E1524; --ts-paper:#FBFAF7; --ts-surface:#fff; --ts-surface-2:#F4F2ED;
  --ts-text:#131A26; --ts-muted:#5A6474; --ts-muted-2:#7A8496;
  --ts-line:rgba(12,18,30,.10); --ts-line-2:rgba(12,18,30,.16);
  --ts-accent:#12B5A8; --ts-accent-d:#0E9488; --ts-accent-l:#5EEAD4; --ts-gold:#F1B24A;
  --ts-on-dark:#E9EFF5; --ts-on-dark-muted:#96A2B4; --ts-line-dark:rgba(255,255,255,.12);
  --ts-display:"Sora",system-ui,sans-serif; --ts-body:"IBM Plex Sans",system-ui,sans-serif; --ts-mono:"IBM Plex Mono",monospace;
}

/* ---------- Base page ---------- */
.ts-page{font-family:var(--ts-body);color:var(--ts-text);line-height:1.62;font-size:17px}
.ts-page h1,.ts-page h2,.ts-page h3{font-family:var(--ts-display);font-weight:700;line-height:1.1;letter-spacing:-.02em;margin:0}
.ts-page p{margin:0}
.ts-page a{color:inherit;text-decoration:none}
.ts-wrap{width:min(1160px,92vw);margin-inline:auto}
.ast-page-builder-template .site-content .ts-page{margin-top:0}

/* ---------- Buttons ---------- */
.ts-btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--ts-accent);color:#04201d !important;
  font-family:var(--ts-body);font-weight:600;font-size:1rem;padding:.9rem 1.5rem;border-radius:999px;border:0;cursor:pointer;
  transition:transform .18s,box-shadow .25s;box-shadow:0 8px 22px -10px rgba(18,181,168,.7);line-height:1.2}
.ts-btn:hover{transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(18,181,168,.75);color:#04201d !important}
.ts-btn .arr{transition:transform .2s}.ts-btn:hover .arr{transform:translateX(4px)}
.ts-btn-lg{padding:1rem 1.75rem;font-size:1.05rem}
.ts-btn-ghost{background:transparent;color:var(--ts-on-dark) !important;box-shadow:none;border:1px solid var(--ts-line-dark)}
.ts-btn-ghost:hover{background:rgba(255,255,255,.06);color:var(--ts-on-dark) !important}
.ts-btn-block{display:flex;width:100%;justify-content:center}

/* ---------- Hero ---------- */
.ts-hero{position:relative;background:var(--ts-ink);color:var(--ts-on-dark);overflow:hidden;isolation:isolate;padding:6rem 0}
.ts-hero-bg{position:absolute;inset:0;z-index:0}
.ts-hero-grid{position:absolute;inset:0;
  background-image:linear-gradient(var(--ts-line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--ts-line-dark) 1px,transparent 1px);
  background-size:64px 64px;opacity:.5;
  -webkit-mask-image:radial-gradient(120% 90% at 70% 0%,#000 30%,transparent 78%);mask-image:radial-gradient(120% 90% at 70% 0%,#000 30%,transparent 78%)}
.ts-glow{position:absolute;border-radius:50%;filter:blur(90px);opacity:.55}
.ts-glow-1{width:620px;height:620px;top:-220px;right:-120px;background:radial-gradient(circle,rgba(18,181,168,.55),transparent 66%)}
.ts-glow-2{width:520px;height:520px;bottom:-260px;left:-140px;background:radial-gradient(circle,rgba(46,110,255,.28),transparent 66%)}
.ts-hero-inner{position:relative;z-index:1;max-width:900px}
.ts-eyebrow{font-family:var(--ts-mono);font-size:.74rem;letter-spacing:.24em;color:var(--ts-accent-l);text-transform:uppercase;margin-bottom:1.4rem}
.ts-hero h1{font-size:clamp(2.5rem,6.4vw,4.6rem);font-weight:800;letter-spacing:-.035em}
.ts-grad{background:linear-gradient(100deg,var(--ts-accent-l),var(--ts-accent));-webkit-background-clip:text;background-clip:text;color:transparent}
.ts-hero-lead{margin-top:1.6rem;font-size:clamp(1.05rem,1.9vw,1.3rem);color:var(--ts-on-dark-muted);max-width:60ch}
.ts-hero-cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.4rem}
.ts-chips{list-style:none;display:flex;flex-wrap:wrap;gap:.6rem;padding:0;margin:2.8rem 0 0}
.ts-chips li{font-family:var(--ts-mono);font-size:.76rem;color:var(--ts-on-dark);padding:.45rem .85rem;border:1px solid var(--ts-line-dark);border-radius:999px;background:rgba(255,255,255,.03)}
.ts-chips li::before{content:"›";color:var(--ts-accent);margin-right:.4rem}

/* ---------- Trust bar ---------- */
.ts-trust{background:var(--ts-ink-2);color:var(--ts-on-dark);border-top:1px solid var(--ts-line-dark)}
.ts-trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding:2.6rem 0}
.ts-trust-item{display:flex;flex-direction:column;gap:.3rem;position:relative;padding-left:1.3rem}
.ts-trust-item::before{content:"";position:absolute;left:0;top:.15rem;bottom:.15rem;width:2px;background:linear-gradient(var(--ts-accent),transparent);border-radius:2px}
.ts-trust-num{font-family:var(--ts-display);font-weight:700;font-size:1.5rem}
.ts-trust-label{font-size:.9rem;color:var(--ts-on-dark-muted)}

/* ---------- Sections ---------- */
.ts-section{padding:6rem 0}
.ts-section-alt{background:var(--ts-surface);border-block:1px solid var(--ts-line)}
.ts-section-dark{background:var(--ts-ink);color:var(--ts-on-dark)}
.ts-sec-eyebrow{font-family:var(--ts-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ts-accent-d);margin-bottom:1rem}
.ts-section-dark .ts-sec-eyebrow{color:var(--ts-accent-l)}
.ts-sec-title{font-size:clamp(1.9rem,3.6vw,2.8rem);max-width:20ch}
.ts-sec-head{max-width:640px;margin-bottom:3.4rem}
.ts-sec-intro{margin-top:1.1rem;color:var(--ts-muted);font-size:1.1rem}
.ts-section-dark .ts-sec-intro{color:var(--ts-on-dark-muted)}

/* ---------- About ---------- */
.ts-about{display:grid;grid-template-columns:1.55fr .85fr;gap:3.5rem;align-items:start}
.ts-prose p{margin-top:1.15rem;color:var(--ts-muted);font-size:1.06rem}
.ts-prose p:first-child{margin-top:1.4rem;color:var(--ts-text);font-size:1.16rem;line-height:1.55}
.ts-card-dark{background:var(--ts-ink);color:var(--ts-on-dark);border-radius:16px;padding:2rem 1.9rem;box-shadow:0 30px 70px -30px rgba(10,18,40,.55);position:sticky;top:100px}
.ts-card-head{display:flex;align-items:center;gap:.6rem;font-family:var(--ts-mono);font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ts-on-dark-muted);margin-bottom:1.4rem}
.ts-pulse{width:9px;height:9px;border-radius:50%;background:var(--ts-accent);animation:tspulse 2.4s infinite}
@keyframes tspulse{0%{box-shadow:0 0 0 0 rgba(18,181,168,.55)}70%{box-shadow:0 0 0 12px rgba(18,181,168,0)}100%{box-shadow:0 0 0 0 rgba(18,181,168,0)}}
.ts-ticks{list-style:none;margin:0 0 1.8rem;padding:0;display:flex;flex-direction:column;gap:.9rem}
.ts-ticks li{position:relative;padding-left:1.9rem;color:var(--ts-on-dark);font-size:1rem}
.ts-ticks li::before{content:"";position:absolute;left:0;top:.15rem;width:1.15rem;height:1.15rem;border-radius:50%;background:rgba(18,181,168,.16) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235EEAD4' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/.72rem no-repeat}

/* ---------- Cards / services ---------- */
.ts-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.ts-scard{background:var(--ts-paper);border:1px solid var(--ts-line);border-radius:16px;padding:2rem 1.8rem;position:relative;overflow:hidden;transition:transform .25s,border-color .25s,box-shadow .25s}
.ts-scard::after{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--ts-accent),var(--ts-accent-l));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.ts-scard:hover{transform:translateY(-5px);border-color:var(--ts-line-2);box-shadow:0 12px 34px -14px rgba(12,18,30,.18)}
.ts-scard:hover::after{transform:scaleX(1)}
.ts-icon{display:grid;place-items:center;width:52px;height:52px;border-radius:13px;background:linear-gradient(150deg,rgba(18,181,168,.14),rgba(94,234,212,.06));color:var(--ts-accent-d);margin-bottom:1.3rem;border:1px solid rgba(18,181,168,.2)}
.ts-scard h3{font-size:1.24rem;margin-bottom:.6rem}
.ts-scard p{color:var(--ts-muted);font-size:1rem}
.ts-services-note{margin-top:2.6rem;text-align:center;color:var(--ts-muted);font-size:1.05rem}
.ts-services-note a{color:var(--ts-accent-d);font-weight:600}

/* ---------- Approach ---------- */
.ts-approach{display:grid;grid-template-columns:.9fr 1.1fr;gap:3.5rem;align-items:start}
.ts-approach-intro{position:sticky;top:100px}
.ts-approach-list{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem 2rem}
.ts-approach-item{display:flex;gap:1rem}
.ts-approach-num{font-family:var(--ts-mono);font-size:.85rem;font-weight:600;color:var(--ts-accent-d);padding-top:.2rem}
.ts-approach-item h3{font-size:1.12rem;margin-bottom:.35rem}
.ts-approach-item p{color:var(--ts-muted);font-size:.98rem}

/* ---------- Contact ---------- */
.ts-contact{display:grid;grid-template-columns:1fr 1.05fr;gap:3.5rem;align-items:start}
.ts-contact-details{list-style:none;padding:0;margin:2.4rem 0 0;display:flex;flex-direction:column;gap:1.4rem}
.ts-contact-details li{display:flex;gap:1rem;align-items:flex-start}
.ts-ci{flex:none;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:rgba(255,255,255,.05);border:1px solid var(--ts-line-dark);color:var(--ts-accent-l);font-size:1.1rem}
.ts-ci-label{display:block;font-family:var(--ts-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ts-on-dark-muted);margin-bottom:.2rem}
.ts-contact-details a{color:var(--ts-on-dark);border-bottom:1px solid transparent}
.ts-contact-details a:hover{border-color:var(--ts-accent-l)}
.ts-formcard{background:var(--ts-surface);color:var(--ts-text);border-radius:16px;padding:2.1rem;box-shadow:0 30px 70px -30px rgba(10,18,40,.55)}
.ts-form{display:flex;flex-direction:column;gap:1.1rem}
.ts-field{display:flex;flex-direction:column;gap:.4rem}
.ts-field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.ts-field label{font-size:.86rem;font-weight:600}
.ts-field .opt{font-weight:400;color:var(--ts-muted-2)}
.ts-form input,.ts-form textarea{font-family:var(--ts-body);font-size:1rem;color:var(--ts-text);padding:.8rem .95rem;border:1px solid var(--ts-line-2);border-radius:11px;background:var(--ts-surface-2);transition:border-color .2s,box-shadow .2s,background .2s;resize:vertical;width:100%}
.ts-form input:focus,.ts-form textarea:focus{outline:none;border-color:var(--ts-accent);background:#fff;box-shadow:0 0 0 4px rgba(18,181,168,.14)}
.ts-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.ts-form-fine{font-size:.8rem;color:var(--ts-muted-2);text-align:center}
.ts-form-fine a{color:var(--ts-accent-d);text-decoration:underline}
.ts-banner{border-radius:11px;padding:1rem 1.15rem;margin-bottom:1.4rem;display:flex;flex-direction:column;gap:.25rem;font-size:.95rem}
.ts-banner strong{font-family:var(--ts-display)}
.ts-banner-ok{background:rgba(18,181,168,.1);border:1px solid rgba(18,181,168,.35);color:#0b5c54}

/* ---------- Site-wide branded footer (via wp_footer) ---------- */
.ts-footer{background:var(--ts-ink);color:var(--ts-on-dark);padding:4.5rem 0 2.4rem;font-family:var(--ts-body)}
.ts-footer a{color:var(--ts-on-dark);text-decoration:none}
.ts-footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid var(--ts-line-dark)}
.ts-footer h4{font-family:var(--ts-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ts-on-dark-muted);margin:0 0 1.1rem;font-weight:500}
.ts-footer-col a{display:block;opacity:.82;padding:.28rem 0;font-size:.96rem}
.ts-footer-col a:hover{opacity:1;color:var(--ts-accent-l)}
.ts-footer-brand-name{font-family:var(--ts-display);font-weight:700;font-size:1.2rem}
.ts-footer-blurb{color:var(--ts-on-dark-muted);font-size:.98rem;max-width:34ch;margin:.8rem 0 0}
.ts-footer-avail{display:flex;align-items:center;gap:.55rem;margin-top:1.2rem;font-size:.88rem}
.ts-footer-avail .ts-dot{width:8px;height:8px;border-radius:50%;background:var(--ts-accent);animation:tspulse 2.4s infinite}
.ts-footer address{font-style:normal;color:var(--ts-on-dark-muted);font-size:.94rem;margin-top:.5rem;line-height:1.7}
.ts-footer-legal{padding-top:2rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem}
.ts-footer-legal p{color:var(--ts-on-dark-muted);font-size:.85rem;max-width:66ch}
.ts-footer-legal strong{color:var(--ts-on-dark)}

/* ---------- Legal pages ---------- */
.ts-legal{max-width:820px}
.ts-legal h2{font-size:1.45rem;margin:2.6rem 0 .9rem}
.ts-legal h2:first-child{margin-top:0}
.ts-legal h3{font-size:1.1rem;margin:1.6rem 0 .5rem}
.ts-legal p,.ts-legal li{color:var(--ts-muted);font-size:1.03rem}
.ts-legal p{margin-top:.9rem}.ts-legal ul{margin:.7rem 0 0;padding-left:1.3rem}.ts-legal li{margin-top:.5rem}
.ts-legal a{color:var(--ts-accent-d);text-decoration:underline}.ts-legal strong{color:var(--ts-text)}
.ts-updated{font-family:var(--ts-mono);font-size:.8rem;color:var(--ts-muted-2)}

/* ---------- Astra header override: dark brand bar ---------- */
header.site-header,.ast-primary-header-bar,.main-header-bar,.ast-above-header,.ast-below-header{background-color:var(--ts-ink) !important}
header.site-header .main-header-menu a,header.site-header .ast-builder-menu a,header.site-header .menu-link,header.site-header .site-title a{color:var(--ts-on-dark) !important}
header.site-header .main-header-menu a:hover,header.site-header .menu-link:hover{color:var(--ts-accent-l) !important}
.site-title,.site-title a{font-family:var(--ts-display) !important;font-weight:700 !important}
.ast-site-identity{padding:.5rem 0}
header.site-header .menu-item.ts-cta a{background:var(--ts-accent);color:#04201d !important;border-radius:999px;padding:.5rem 1.1rem !important;margin-left:.5rem}
.ast-mobile-menu-buttons-minimal,.ast-button-wrap .menu-toggle{color:var(--ts-on-dark) !important;background:transparent !important}
.main-header-menu,.ast-builder-menu .main-header-menu{background:var(--ts-ink) !important}
.ast-header-break-point .main-header-bar .main-header-menu .menu-item a{border-color:var(--ts-line-dark)}

/* hide Astra default footer, we print our own */
footer.site-footer{display:none !important}

/* ---------- WooCommerce brand tweaks ---------- */
.woocommerce a.button,.woocommerce button.button,.woocommerce .button.alt,.woocommerce #respond input#submit{
  background:var(--ts-accent) !important;color:#04201d !important;border-radius:999px !important;font-family:var(--ts-body) !important;font-weight:600 !important}
.woocommerce a.button:hover,.woocommerce button.button:hover{background:var(--ts-accent-d) !important}
.woocommerce ul.products li.product .price{color:var(--ts-accent-d)}
.woocommerce-message,.woocommerce-info{border-top-color:var(--ts-accent) !important}

/* ---------- Reveal ---------- */
.ts-reveal{opacity:0;transform:translateY(18px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);transition-delay:var(--d,0s)}
.ts-reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.ts-reveal{opacity:1;transform:none}.ts-pulse,.ts-dot{animation:none}}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .ts-about,.ts-approach,.ts-contact{grid-template-columns:1fr}
  .ts-card-dark,.ts-approach-intro{position:static}
  .ts-cards{grid-template-columns:repeat(2,1fr)}
  .ts-footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .ts-trust-grid{grid-template-columns:1fr 1fr}
  .ts-approach-list{grid-template-columns:1fr}
  .ts-section{padding:4.5rem 0}.ts-hero{padding:4rem 0}
}
@media (max-width:520px){
  .ts-cards{grid-template-columns:1fr}.ts-field-row{grid-template-columns:1fr}
  .ts-footer-grid,.ts-footer-legal{grid-template-columns:1fr;flex-direction:column}
}
