/*
Theme Name: TimeSaved Accounting
Theme URI: https://timsavedap.com
Author: TimeSaved Accounting Partners
Author URI: https://timsavedap.com
Description: Custom theme for TimeSaved Accounting Partners LLC. Modern, professional, AI-infused bookkeeping website for growing businesses.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: timesaved-accounting
*/

:root {
  --navy: #0d2a4a;
  --turquoise: #11b7b1;
  --money-green: #1b9c5a;
  --gold: #c8a64f;
  --white: #ffffff;
  --ink: #10243d;
  --ink-soft: #385171;
  --bg: #f4f9fc;
  --card: #ffffff;
  --shadow: 0 20px 45px rgba(13, 42, 74, 0.12);
  --radius: 18px;
  --container: 1200px;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
}

body {
  font-family: "Avenir Next", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  color: var(--ink);
  background: radial-gradient(circle at 15% 10%, rgba(17, 183, 177, 0.09), transparent 42%),
    radial-gradient(circle at 90% 0%, rgba(200, 166, 79, 0.15), transparent 40%),
    var(--bg);
  line-height: 1.6;
}

a {
  color: var(--navy);
  text-decoration: none;
}

a:hover {
  color: var(--money-green);
}

img {
  max-width: 100%;
  height: auto;
}

.container {
  width: min(92%, var(--container));
  margin: 0 auto;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255, 255, 255, 0.93);
  border-bottom: 1px solid rgba(13, 42, 74, 0.09);
  backdrop-filter: blur(8px);
  padding: 4px 0;
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 166px;
  gap: 1rem;
}

.brand-title {
  margin: 0;
  font-size: clamp(1rem, 1.8vw, 1.3rem);
  color: var(--navy);
  line-height: 1.25;
}

.brand-title span {
  display: block;
  font-size: 0.8rem;
  color: var(--ink-soft);
  font-weight: 500;
}

.brand-logo-link {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
}

.brand-logo {
  height: 162px;
  width: auto;
  display: block;
  object-fit: contain;
}

.site-nav ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 1rem;
}

.site-nav a {
  font-weight: 600;
  color: var(--ink);
}

.btn {
  display: inline-block;
  border: none;
  border-radius: 999px;
  padding: 0.8rem 1.3rem;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn-primary {
  background: linear-gradient(130deg, var(--navy), #174878);
  color: var(--white);
  box-shadow: 0 14px 30px rgba(13, 42, 74, 0.25);
}

.btn-secondary {
  background: linear-gradient(130deg, var(--money-green), #15b56a);
  color: var(--white);
  box-shadow: 0 14px 30px rgba(27, 156, 90, 0.25);
}

.btn-ghost {
  background: var(--white);
  color: var(--navy);
  border: 1px solid rgba(13, 42, 74, 0.2);
}

.hero {
  padding: clamp(4rem, 8vw, 7rem) 0 3rem;
}

.hero-wrap {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(1.5rem, 3vw, 3rem);
  align-items: center;
}

.kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(17, 183, 177, 0.12);
  color: var(--navy);
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.hero h1 {
  font-size: clamp(2.2rem, 5vw, 4rem);
  line-height: 1.08;
  margin: 0.8rem 0 0.7rem;
}

.hero h2 {
  margin: 0;
  color: var(--ink-soft);
  font-size: clamp(1.2rem, 2vw, 1.5rem);
}

.hero p {
  font-size: 1.05rem;
  max-width: 62ch;
}

.cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.4rem;
}

.hero-card {
  background: linear-gradient(160deg, var(--card), #f9fffc);
  border: 1px solid rgba(13, 42, 74, 0.08);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 1.4rem;
}

.hero-card h3 {
  margin-top: 0;
  margin-bottom: 0.35rem;
}

.badge-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(120px, 1fr));
  gap: 0.7rem;
  margin-top: 1rem;
}

.badge {
  background: #fff;
  border: 1px solid rgba(13, 42, 74, 0.08);
  border-radius: 12px;
  padding: 0.65rem;
  font-size: 0.9rem;
  font-weight: 600;
}

section {
  padding: clamp(3rem, 6vw, 5rem) 0;
}

.section-title {
  margin: 0 0 0.6rem;
  font-size: clamp(1.65rem, 3vw, 2.5rem);
}

.section-intro {
  color: var(--ink-soft);
  margin: 0 0 1.8rem;
  max-width: 75ch;
}

.grid-3,
.grid-4,
.grid-2 {
  display: grid;
  gap: 1rem;
}

.grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.card {
  background: var(--card);
  border: 1px solid rgba(13, 42, 74, 0.09);
  border-radius: var(--radius);
  padding: 1.2rem;
  box-shadow: 0 8px 25px rgba(13, 42, 74, 0.06);
}

.card h3 {
  margin-top: 0;
}

.tick-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.tick-list li {
  position: relative;
  padding-left: 1.5rem;
  margin: 0.55rem 0;
}

.tick-list li::before {
  content: "\2714";
  position: absolute;
  left: 0;
  color: var(--money-green);
  font-weight: 900;
}

.highlight {
  background: linear-gradient(145deg, var(--navy), #123a64);
  color: #e8f4ff;
}

.highlight .section-title,
.highlight h3,
.highlight p,
.highlight li {
  color: #e8f4ff;
}

.packages {
  align-items: stretch;
}

.package {
  position: relative;
  overflow: hidden;
}

.package::after {
  content: "";
  position: absolute;
  inset: auto -15% -60% -15%;
  height: 200px;
  background: radial-gradient(circle at center, rgba(17, 183, 177, 0.17), transparent 65%);
  pointer-events: none;
}

.price {
  font-size: 1.7rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0.2rem 0 0.7rem;
}

.cta-band {
  text-align: center;
  padding: clamp(2.4rem, 4vw, 3.5rem) 1rem;
  border-radius: var(--radius);
  background: linear-gradient(130deg, #0f3a63, #14707f 60%, #1b9c5a);
  color: #fff;
}

.cta-band h2 {
  margin-top: 0;
}

.form-card {
  background: var(--card);
  border: 1px solid rgba(13, 42, 74, 0.1);
  border-radius: var(--radius);
  padding: 1.4rem;
  box-shadow: var(--shadow);
}

label {
  display: block;
  font-weight: 700;
  margin: 0.5rem 0 0.3rem;
}

input,
select,
textarea {
  width: 100%;
  padding: 0.75rem 0.8rem;
  border: 1px solid rgba(13, 42, 74, 0.2);
  border-radius: 12px;
  font-size: 1rem;
  font-family: inherit;
}

textarea {
  min-height: 140px;
}

.site-footer {
  background: #07172b;
  color: #dce8f4;
  padding: 2rem 0;
  margin-top: 2rem;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 1rem;
  align-items: center;
}

.footer-grid p {
  margin: 0.25rem 0;
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.8rem;
}

.footer-links a {
  color: #dce8f4;
}

.mobile-toggle {
  display: none;
}

.notice {
  border-radius: 12px;
  padding: 0.8rem 1rem;
  margin-bottom: 1rem;
  border: 1px solid;
}

.notice-success {
  background: rgba(27, 156, 90, 0.12);
  border-color: rgba(27, 156, 90, 0.45);
  color: #125d37;
}

.notice-error {
  background: rgba(180, 34, 34, 0.1);
  border-color: rgba(180, 34, 34, 0.35);
  color: #792323;
}

@media (max-width: 980px) {
  .hero-wrap,
  .grid-4,
  .grid-3,
  .grid-2,
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .mobile-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(13, 42, 74, 0.2);
    border-radius: 10px;
    background: #fff;
    padding: 0.5rem 0.7rem;
    font-size: 0.95rem;
    font-weight: 700;
  }

  .site-nav {
    display: none;
    position: absolute;
    top: 80px;
    left: 0;
    right: 0;
    background: #fff;
    border-bottom: 1px solid rgba(13, 42, 74, 0.09);
    padding: 0.8rem 1rem;
  }

  .site-nav.open {
    display: block;
  }

  .site-nav ul {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.45rem;
  }

  .footer-links {
    justify-content: flex-start;
  }
}

/* ===== Pretty V2 Overrides ===== */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Playfair+Display:wght@700;800&display=swap');

:root{
  --navy:#0a2342;
  --turquoise:#08b8c8;
  --money-green:#1f9d63;
  --gold:#d4af37;
  --soft:#f6fbff;
  --ink:#10243d;
}

body{
  font-family:"Manrope","Segoe UI",Arial,sans-serif;
  background:
    radial-gradient(1200px 500px at -5% -10%, rgba(8,184,200,.15), transparent 55%),
    radial-gradient(1000px 450px at 110% -10%, rgba(212,175,55,.16), transparent 50%),
    linear-gradient(180deg,#f8fcff 0%,#eef6fb 100%);
  color:var(--ink);
}

h1,h2,h3,.section-title{
  font-family:"Playfair Display","Times New Roman",serif;
  letter-spacing:.2px;
}

.site-header{
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(10,35,66,.10);
}

.brand-title{
  color:var(--navy);
}
.brand-title span{
  color:#356286;
}

.hero{
  padding-top:clamp(4rem,8vw,7rem);
}
.hero h1{
  color:var(--navy);
  text-shadow:0 10px 30px rgba(10,35,66,.18);
}
.hero h2{
  color:#2f5f86;
}
.kicker{
  background:linear-gradient(135deg,rgba(8,184,200,.18),rgba(31,157,99,.18));
  border:1px solid rgba(8,184,200,.30);
  color:#0f446f;
  font-weight:800;
}
.hero-card{
  border:1px solid rgba(10,35,66,.12);
  box-shadow:0 24px 50px rgba(10,35,66,.16);
  background:linear-gradient(160deg,#fff, #f4fffb);
}

.section-title{
  position:relative;
  display:inline-block;
  margin-bottom:1rem;
}
.section-title::after{
  content:"";
  display:block;
  width:62%;
  height:4px;
  margin-top:.35rem;
  border-radius:10px;
  background:linear-gradient(90deg,var(--turquoise),var(--gold));
}

.card{
  border:1px solid rgba(10,35,66,.10);
  box-shadow:0 12px 28px rgba(10,35,66,.09);
  transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 38px rgba(10,35,66,.15);
}

.highlight{
  background:linear-gradient(130deg,#0a2342 0%,#0f4f73 55%,#1f9d63 100%);
}
.highlight .card{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.24);
  color:#fff;
  box-shadow:none;
}

.btn{
  border-radius:999px;
  font-weight:800;
}
.btn-primary{
  background:linear-gradient(135deg,#0a2342,#134c76);
  box-shadow:0 14px 28px rgba(10,35,66,.28);
}
.btn-secondary{
  background:linear-gradient(135deg,#1f9d63,#08b8c8);
  box-shadow:0 14px 28px rgba(31,157,99,.28);
}
.btn-ghost{
  border:1px solid rgba(10,35,66,.2);
  background:#fff;
}

.package{
  border:1px solid rgba(10,35,66,.12);
}
.price{
  color:#0d3a63;
}
.package .btn{
  width:100%;
  text-align:center;
}

.cta-band{
  background:linear-gradient(135deg,#0a2342,#0f4f73 60%,#1f9d63);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 24px 50px rgba(10,35,66,.24);
}

.site-footer{
  background:linear-gradient(180deg,#071a31,#061225);
}
.site-footer a:hover{
  color:#7de3ee;
}




/* BEGIN HERO PHOTO FORCE */
body.home .hero{
  min-height: 740px !important;
  padding: 6rem 0 5rem !important;
  background:
    linear-gradient(120deg, rgba(7,24,46,.58), rgba(10,35,66,.42)),
    url('/wp-content/themes/timesaved-accounting/assets/img/hero-photo.jpg') center 35%/cover no-repeat !important;
  border-bottom: 1px solid rgba(255,255,255,.18);
}
body.home .hero::before,
body.home .hero::after{
  display:none !important;
  content:none !important;
}

body.home .hero .hero-wrap{
  grid-template-columns: 1fr !important;
  max-width: 920px;
}

body.home .hero .hero-card{
  display:none !important;
}

body.home .hero h1,
body.home .hero h2,
body.home .hero p,
body.home .hero .kicker{
  color:#fff !important;
  text-shadow: 0 2px 12px rgba(0,0,0,.25);
}

body.home .hero p{
  max-width: 64ch;
  background: rgba(8,26,49,.26);
  padding: .8rem 1rem;
  border-radius: 12px;
}

@media (max-width: 980px){
  body.home .hero{
    min-height: 560px !important;
    padding: 4rem 0 3rem !important;
    background-position: 58% center !important;
  }
}
/* END HERO PHOTO FORCE */

/* BEGIN BIG VISUAL V3 */
.big-visual-home .hero-photo{
  position:relative;
  min-height:760px;
  background:
    linear-gradient(115deg, rgba(7,25,47,.58), rgba(8,47,72,.48)),
    url('/wp-content/themes/timesaved-accounting/assets/img/people/hero-team.jpg') center/cover no-repeat !important;
}
.big-visual-home .hero-overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(circle at 85% 20%, rgba(8,184,200,.30), transparent 36%),
    radial-gradient(circle at 20% 82%, rgba(212,175,55,.20), transparent 42%);
  pointer-events:none;
}
.big-visual-home .hero-wrap{ position:relative; z-index:2; }
.big-visual-home .hero h1,
.big-visual-home .hero h2,
.big-visual-home .hero p,
.big-visual-home .hero .kicker{ color:#fff !important; text-shadow:0 2px 12px rgba(0,0,0,.25); }

.big-visual-home .hero-card{
  background:rgba(255,255,255,.93) !important;
  box-shadow:0 24px 52px rgba(8,23,44,.30) !important;
}

.image-strip, .image-grid-4{
  display:grid;
  gap:1rem;
}
.image-strip{ grid-template-columns:repeat(3,minmax(0,1fr)); margin-top:1rem; }
.image-grid-4{ grid-template-columns:repeat(4,minmax(0,1fr)); margin-top:1rem; }

.img-card, .image-grid-4 figure, .media-panel{
  border-radius:16px; overflow:hidden;
  box-shadow:0 16px 34px rgba(8,23,44,.18);
}
.img-card img, .image-grid-4 img, .media-panel img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .45s ease;
}
.img-card:hover img, .image-grid-4 figure:hover img, .media-panel:hover img{ transform:scale(1.06); }

.problem-block .media-panel{ min-height:340px; }

.services-visual .card{
  background:linear-gradient(180deg, #fff, #f4fbff);
  border:1px solid rgba(10,35,66,.10);
}

.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:all .7s ease;
}
.reveal.in{
  opacity:1;
  transform:translateY(0);
}

@media (max-width: 980px){
  .image-strip{ grid-template-columns:1fr; }
  .image-grid-4{ grid-template-columns:repeat(2,minmax(0,1fr)); }
  .big-visual-home .hero-photo{ min-height:620px; background-position:62% center !important; }
}
@media (max-width: 640px){
  .image-grid-4{ grid-template-columns:1fr; }
}
/* END BIG VISUAL V3 */

/* BEGIN DIVERSE FULLWIDTH V1 */
body.home .big-visual-home,
body.home .big-visual-home section{
  width:100% !important;
  max-width:none !important;
}

body.home .big-visual-home .container{
  width:min(96%, 1680px) !important;
  max-width:1680px !important;
}

body.home .big-visual-home .hero-photo{
  min-height:780px !important;
  background:
    linear-gradient(115deg, rgba(8,24,45,.56), rgba(8,48,73,.42)),
    url('/wp-content/themes/timesaved-accounting/assets/img/people/hero-team.jpg') center/cover no-repeat !important;
}

body.home .big-visual-home .hero-wrap{
  grid-template-columns: 1.1fr .9fr !important;
  gap: 2rem !important;
}

body.home .image-strip{
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
}
body.home .image-grid-4{
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
}

body.home .img-card,
body.home .image-grid-4 figure,
body.home .media-panel{
  border-radius:18px !important;
  overflow:hidden !important;
  box-shadow:0 18px 36px rgba(8,23,44,.20) !important;
}

body.home .img-card img,
body.home .image-grid-4 img,
body.home .media-panel img{
  width:100% !important;
  height:100% !important;
  min-height:280px !important;
  object-fit:cover !important;
}

@media (max-width: 1100px){
  body.home .big-visual-home .hero-wrap{
    grid-template-columns:1fr !important;
  }
  body.home .image-grid-4{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
}
@media (max-width: 700px){
  body.home .image-strip,
  body.home .image-grid-4{
    grid-template-columns:1fr !important;
  }
}
/* END DIVERSE FULLWIDTH V1 */

/* BEGIN TSA EYECANDY V1 */
.footer-bottom-line{
  margin-top: 1.4rem;
  padding-top: .9rem;
  border-top: 1px solid rgba(255,255,255,.2);
  text-align: center;
}
.footer-bottom-line p{
  margin: 0;
  font-weight: 700;
  color: #e8f3ff;
  letter-spacing: .2px;
}

.tsa-caption-showcase{
  padding: 4.5rem 0;
  background:
    radial-gradient(circle at 10% 10%, rgba(8,184,200,.12), transparent 45%),
    radial-gradient(circle at 90% 90%, rgba(31,157,99,.12), transparent 45%),
    linear-gradient(180deg, #f6fbff 0%, #edf7ff 100%);
}
.caption-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 1rem;
}
.caption-card{
  background:#fff;
  border:1px solid rgba(10,35,66,.1);
  border-radius:16px;
  padding:1rem 1.1rem;
  box-shadow:0 10px 24px rgba(10,35,66,.10);
}
.caption-card h3{ margin:.1rem 0 .45rem; }

.saying-ribbon{
  margin-top:1.2rem;
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
}
.saying-ribbon span{
  display:inline-block;
  background:linear-gradient(135deg,#0a2342,#0f4f73 65%,#1f9d63);
  color:#fff;
  border-radius:999px;
  padding:.55rem .95rem;
  font-weight:700;
  font-size:.92rem;
  box-shadow:0 8px 18px rgba(10,35,66,.2);
}

@media (max-width: 980px){
  .caption-grid{ grid-template-columns:1fr; }
}
/* END TSA EYECANDY V1 */

/* BEGIN TSA STORY V1 */
.tsa-hero-slider{
  position:relative;
  min-height:760px;
  overflow:hidden;
}
.tsa-slide{
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  opacity:0;
  transition:opacity .9s ease;
}
.tsa-slide.active{ opacity:1; }
.tsa-hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(115deg, rgba(8,22,42,.58), rgba(8,47,72,.42));
}
.tsa-hero-content{
  position:relative; z-index:2;
  padding:5.5rem 0 4rem;
  color:#fff;
}
.tsa-hero-content h1,.tsa-hero-content h2,.tsa-hero-content p,.tsa-hero-content .kicker{
  color:#fff !important;
  text-shadow:0 2px 12px rgba(0,0,0,.25);
}
.hero-copy{
  max-width:64ch;
  background:rgba(8,26,49,.28);
  padding:.8rem 1rem;
  border-radius:12px;
}
.tsa-founder-strip{ padding:4rem 0; }
.tsa-founder-photo{
  margin:0;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 18px 36px rgba(8,23,44,.2);
}
.tsa-founder-photo img{
  width:100%; height:100%; min-height:420px; object-fit:cover;
}
.tsa-story-gallery{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1rem;
}
.tsa-story-item{
  margin:0; border-radius:14px; overflow:hidden;
  box-shadow:0 12px 26px rgba(8,23,44,.15);
}
.tsa-story-item img{
  width:100%; height:230px; object-fit:cover; display:block;
  transition:transform .35s ease;
}
.tsa-story-item:hover img{ transform:scale(1.05); }

@media (max-width: 1100px){
  .tsa-story-gallery{ grid-template-columns:repeat(3,minmax(0,1fr)); }
}
@media (max-width: 900px){
  .tsa-hero-slider{ min-height:620px; }
  .tsa-story-gallery{ grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width: 600px){
  .tsa-story-gallery{ grid-template-columns:1fr; }
}
/* END TSA STORY V1 */

/* BEGIN TSA ABOUT FOUNDER V2 */
.tsa-about-page .about-founder-wrap{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:1.2rem;
  align-items:stretch;
}
.tsa-about-page .founder-copy blockquote{
  margin:1rem 0 0;
  padding:.9rem 1rem;
  border-left:4px solid var(--gold);
  background:rgba(8,184,200,.08);
  border-radius:10px;
  font-style:italic;
}
.tsa-about-page .founder-portrait{
  margin:0;
  background:#fff;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 16px 34px rgba(8,23,44,.16);
  display:flex;
  flex-direction:column;
  padding:20px 20px 0;
}
.tsa-about-page .founder-portrait img{
  width:100%;
  height:420px;
  object-fit:contain;
  object-position:center 60%;
  border-radius:8px;
  margin-top:6%;
}
.tsa-about-page .founder-portrait figcaption{
  padding:.9rem 1rem;
  font-weight:800;
  color:var(--navy);
  text-align:center;
}
.tsa-about-page .founder-portrait figcaption span{
  display:block;
  font-weight:600;
  color:var(--ink-soft);
  font-size:.9rem;
  text-align:center;
}
@media (max-width: 980px){
  .tsa-about-page .about-founder-wrap{
    grid-template-columns:1fr;
  }
  .tsa-about-page .founder-portrait img{
    height:340px;
    margin-top:4%;
  }
}
/* END TSA ABOUT FOUNDER V2 */

/* BEGIN TSA CLEAN HOME V1 */
.tsa-clean-home .tsa-story-row{ padding:3.5rem 0; }
.tsa-clean-home .story-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:1.2rem;
  align-items:center;
}
.tsa-clean-home .story-grid figure{
  margin:0;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 14px 30px rgba(8,23,44,.16);
}
.tsa-clean-home .story-grid img{
  width:100%;
  height:360px;
  object-fit:cover;
  display:block;
}
.tsa-clean-home .story-grid .card{
  padding:1.4rem;
  border-radius:16px;
}
.tsa-clean-home .tsa-story-row.alt{
  background:linear-gradient(180deg,#f7fbff,#eef7ff);
}
@media (max-width:980px){
  .tsa-clean-home .story-grid{
    grid-template-columns:1fr;
  }
  .tsa-clean-home .story-grid img{
    height:280px;
  }
}
/* END TSA CLEAN HOME V1 */

/* SurgeXi pulsating link */
@keyframes surgexi-pulse {
  0%, 100% { opacity: 1; color: #ffffff; }
  50%       { opacity: 0.35; color: #ffffff; }
}
.footer-bottom-line a[href*="surgexi"] {
  color: #ffffff;
  text-decoration: none;
  font-weight: 700;
  animation: surgexi-pulse 2s ease-in-out infinite;
}
.footer-bottom-line a[href*="surgexi"]:hover {
  animation: none;
  opacity: 1;
  color: #ffffff;
  text-decoration: underline;
}
