/* ================================
   Base, Reset & Motion Preferences
   ================================ */

/* Reset */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Sora', 'Space Grotesk', sans-serif;
  line-height: 1.6;
  color: #fff;
  overflow-x: hidden;
  font-weight: 400;
  background: #000; /* sensible default */
}

/* Design Tokens */
:root{
  --c-bg-0:#000000;
  --c-bg-1:#0D0D0D;
  --c-bg-2:#1A1A1A;
  --c-accent:#00FF88;
  --c-accent-weak:rgba(0,255,136,0.3);
  --c-muted:#B3B3B3;
  --shadow-accent-12:0 0 12px rgba(0,255,136,0.6);
  --shadow-accent-20:0 0 20px rgba(0,255,136,0.8);
  --radius:12px;
  --easing:cubic-bezier(0.4,0,0.2,1);
  --t-2:0.2s;
  --t-3:0.3s;
  --t-4:0.4s;
  --t-6:0.6s;
  --t-8:0.8s;
}

/* Respect users who prefer reduced motion */
@media (prefers-reduced-motion: reduce){
  * {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

/* Layout Helpers */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
}

h1,h2,h3{
  font-weight:600;
  letter-spacing:.5px;
  line-height:1.3;
}

.section-headline{
  font-size: clamp(2rem, 4vw, 3rem);
  margin-bottom: 3rem;
  text-align: center;
}

/* =================
   Animation Library
   ================= */

.fade-in,
.slide-in-left,
.slide-in-right,
.scale-in,
.stagger-animation{
  opacity:0;
  will-change: transform, opacity;
}

.fade-in{
  transform: translateY(20px);
  transition: opacity var(--t-8) ease-out, transform var(--t-8) ease-out;
}
.fade-in.visible{
  opacity:1;
  transform:translateY(0);
}

.slide-in-left{
  transform: translateX(-30px);
  transition: opacity var(--t-8) ease-out, transform var(--t-8) ease-out;
}
.slide-in-left.visible{
  opacity:1;
  transform: translateX(0);
}

.slide-in-right{
  transform: translateX(30px);
  transition: opacity var(--t-8) ease-out, transform var(--t-8) ease-out;
}
.slide-in-right.visible{
  opacity:1;
  transform: translateX(0);
}

.scale-in{
  transform: scale(.95);
  transition: opacity var(--t-8) ease-out, transform var(--t-8) ease-out;
}
.scale-in.visible{
  opacity:1;
  transform: scale(1);
}

.stagger-animation{
  transform: translateY(15px);
  transition: opacity var(--t-6) ease-out, transform var(--t-6) ease-out;
}
.stagger-animation.visible{
  opacity:1;
  transform: translateY(0);
}

/* Keyframes (single, deduped set) */
@keyframes slideInFromLeft{
  from{opacity:0; transform:translateX(-100px);}
  to  {opacity:1; transform:translateX(0);}
}
@keyframes slideInFromRight{
  from{opacity:0; transform:translateX(100px);}
  to  {opacity:1; transform:translateX(0);}
}
@keyframes fadeInUpKF{
  from{opacity:0; transform:translateY(50px);}
  to  {opacity:1; transform:translateY(0);}
}
@keyframes scaleInKF{
  from{opacity:0; transform:scale(.5);}
  to  {opacity:1; transform:scale(1);}
}
@keyframes bounceIn{
  0%  {opacity:0; transform:scale(.3);}
  50% {opacity:1; transform:scale(1.05);}
  70% {transform:scale(.9);}
  100%{opacity:1; transform:scale(1);}
}
@keyframes float {
  0%,100%{ transform: translateY(0); }
  50%    { transform: translateY(-10px); }
}
@keyframes glow {
  from { text-shadow: 0 0 12px rgba(0,255,136,.6); }
  to   { text-shadow: 0 0 20px rgba(0,255,136,.8); }
}
@keyframes pulseGlow {
  0%  { box-shadow: var(--shadow-accent-12); }
  50% { box-shadow: 0 0 25px rgba(0,255,136,.8); }
  100%{ box-shadow: var(--shadow-accent-12); }
}
@keyframes gridMove {
  0%   { transform: translate(0,0); }
  100% { transform: translate(50px,50px); }
}

/* =================
   Header & Nav
   ================= */

.header{
  position: fixed;
  inset: 0 0 auto 0;
  background: rgba(0,0,0,.9);
  backdrop-filter: blur(10px);
  z-index: 1000;
  padding: 1rem 0;
  contain: layout paint style;
  isolation: isolate;
}

.header-content{
  display:flex;
  justify-content: space-between;
  align-items:center;
  position:relative;
}

.logo-img,
.mobile-logo-img{
  height:40px;
  width:auto;
  cursor:pointer;
  transition: opacity var(--t-3) ease;
}
.logo-img:hover,
.mobile-logo-img:hover{ opacity:.8; }

.nav{
  display:flex;
  gap:2rem;
}
.nav-link{
  color:#fff;
  text-decoration:none;
  font-weight:500;
  transition: color var(--t-3) ease;
}
.nav-link:hover{ color: var(--c-accent); }

/* Mobile Burger */
.mobile-burger-container{
  position: fixed;
  top:1vh;
  right:1vw;
  z-index:1005;
  display:none; /* shown on <=768px */
  contain: layout style paint;
  isolation:isolate;
}

.burger-menu{
  display:flex;
  flex-direction:column;
  background:none;
  border:none;
  cursor:pointer;
  padding:.5rem;
  position:relative;
}

.burger-line{
  width:25px;
  height:3px;
  background:#fff;
  margin:3px 0;
  transition: transform var(--t-3) var(--easing), opacity var(--t-3) var(--easing);
  border-radius:2px;
}

.burger-menu.active .burger-line:nth-child(1){ transform: rotate(45deg) translate(6px,6px); }
.burger-menu.active .burger-line:nth-child(2){ opacity:0; }
.burger-menu.active .burger-line:nth-child(3){ transform: rotate(-45deg) translate(6px,-6px); }

/* Mobile Nav Drawer */
.mobile-nav{
  position: fixed;
  inset:0;
  width:100vw;
  height:100vh;
  background: rgba(0,0,0,.98);
  backdrop-filter: blur(10px);
  opacity:0;
  visibility:hidden;
  transition: opacity var(--t-3) ease, visibility var(--t-3) ease;
  z-index:1000;
  display:flex;
  flex-direction:column;
}
.mobile-nav.active{
  opacity:1;
  visibility:visible;
}

.mobile-nav-header{
  display:flex;
  justify-content:flex-start;
  align-items:center;
  padding:2rem;
  border-bottom:1px solid rgba(255,255,255,.1);
  flex-shrink:0;
}

.mobile-nav-logo{ flex:1; }

.mobile-nav-close{
  background:none;
  border:none;
  cursor:pointer;
  padding:1rem;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  width:50px;
  height:50px;
  margin:0 auto;
  align-self:center;
  order:-1;
}
.close-line{
  width:25px;
  height:3px;
  background:#fff;
  margin:2px 0;
  transition: transform var(--t-3) var(--easing);
  border-radius:2px;
}
.mobile-nav-close .close-line:nth-child(1){ transform: rotate(45deg) translate(3px,3px); }
.mobile-nav-close .close-line:nth-child(2){ transform: rotate(-45deg) translate(3px,-3px); }

.mobile-nav-content{
  display:flex;
  flex-direction:column;
  padding:2rem;
  gap:1.5rem;
  flex:1;
  justify-content:center;
  align-items:center;
}
.mobile-nav-link{
  color:#fff;
  text-decoration:none;
  font-weight:500;
  font-size:1.5rem;
  padding:1rem 0;
  text-align:center;
  border-bottom:1px solid rgba(255,255,255,.1);
  transition: color var(--t-3) ease;
}
.mobile-nav-link:hover{ color: var(--c-accent); }
.mobile-nav-link:last-child{ border-bottom:none; }

/* =============
   Hero Section
   ============= */

.hero{
  height:100vh;
  background: var(--c-bg-0);
  display:flex;
  align-items:center;
  position:relative;
  overflow:hidden;
  padding-top:80px; /* space for fixed header */
}

.hero-background{
  position:absolute; inset:0;
  z-index:1;
}
#particleCanvas{ width:100%; height:100%; }

.hero-image-overlay{
  position:absolute; inset:0;
  z-index:0;
  opacity:.4;
}
.hero-visual{
  width:100%; height:100%;
  object-fit:cover; object-position:center;
}

.hero-content{
  position:relative; z-index:2;
  max-width:1200px; margin:0 auto; padding:0 2rem; width:100%;
}

.hero-headline{
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight:600;
  margin-bottom:1.5rem;
  line-height:1.3;
  letter-spacing:.5px;
  color:#fff;
}

.ai-text{
  color: var(--c-accent);
  text-shadow: 0 0 12px rgba(0,255,136,.6);
  animation: glow 2s ease-in-out infinite alternate, float 3s ease-in-out infinite;
}

.hero-subtext{
  color: var(--c-muted);
  font-size:1.125rem;
  max-width:600px;
  line-height:1.5;
  margin-bottom:2.5rem;
}

/* CTA Buttons */
.cta-button,
.final-cta-button{
  display:inline-block;
  background: var(--c-accent);
  color:#000;
  padding:1rem 2rem;
  border-radius:8px;
  text-decoration:none;
  font-weight:600;
  font-size:1.125rem;
  transition: transform var(--t-3) var(--easing), box-shadow var(--t-3) var(--easing);
  box-shadow: var(--shadow-accent-12);
  animation: pulseGlow 2s ease-in-out infinite;
}
.cta-button:hover,
.final-cta-button:hover{
  transform: scale(1.05);
  box-shadow: var(--shadow-accent-20);
}

/* ======================
   Philosophy (Manifesto)
   ====================== */

.philosophy{
  background: linear-gradient(135deg, var(--c-bg-1), var(--c-bg-2));
  color:#fff;
  padding:6rem 0;
  position:relative;
  overflow:hidden;
}
.philosophy::before{
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(circle at 20% 30%, rgba(179,179,179,.03) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(0,255,136,.02) 0%, transparent 50%),
    radial-gradient(circle at 50% 20%, rgba(179,179,179,.02) 0%, transparent 50%),
    radial-gradient(circle at 30% 80%, rgba(0,255,136,.03) 0%, transparent 50%);
  animation: philosophyFlow 25s ease-in-out infinite;
  z-index:1;
  pointer-events:none;
}
@keyframes philosophyFlow{
  0%,100%{ opacity:.3; transform: translateY(0) scale(1); }
  25%    { opacity:.5; transform: translateY(-5px) scale(1.01); }
  50%    { opacity:.4; transform: translateY(-10px) scale(1.02); }
  75%    { opacity:.6; transform: translateY(-5px) scale(1.01); }
}

.philosophy-content{
  display:flex; flex-direction:column; align-items:center;
  position:relative; z-index:2;
}

.philosophy-content-new{
  width:90%; max-width:1200px; margin:0 auto;
  border:1px solid rgba(179,179,179,.2);
  border-radius:var(--radius);
  padding:2rem;
  background: rgba(0,0,0,.1);
  backdrop-filter: blur(5px);
}

.manifesto-text{ text-align:center; margin-bottom:3rem; }
.manifesto-text p{
  font-size:1.25rem; line-height:1.6; margin-bottom:2rem; color:var(--c-muted);
  max-width:900px; margin-left:auto; margin-right:auto;
}
.philosophy-highlight{
  color:#fff;
  font-size:1.4rem;
  font-weight:600;
  margin-bottom:2rem;
}
.highlight-text{
  color: var(--c-accent);
  font-weight:600;
  text-shadow: 0 0 8px rgba(0,255,136,.4);
}

.philosophy-visual{
  position:relative; height:400px; width:100%; max-width:800px; margin:0 auto;
}
.philosophy-img{
  width:100%; height:100%; object-fit:cover; border-radius:var(--radius);
  transition: transform var(--t-3) var(--easing);
}
.philosophy-img:hover{ transform: scale(1.05); }

/* ==================
   What We Do / Cards
   ================== */

.what-we-do{ background: var(--c-bg-2); padding:6rem 0; }

.services-grid{
  display:grid;
  grid-template-columns: repeat(3,1fr);
  gap:2rem;
}

.service-card{
  background: var(--c-bg-1);
  border-radius:var(--radius);
  overflow:hidden;
  border:2px solid transparent;
  transition: transform var(--t-3) var(--easing), box-shadow var(--t-3) var(--easing), border-color var(--t-3) var(--easing);
}
.service-card:nth-child(1){
  border-color:#0066FF;
  box-shadow: 0 0 15px rgba(0,102,255,.3);
}
.service-card:nth-child(2){
  border-color: var(--c-accent);
  box-shadow: 0 0 15px var(--c-accent-weak);
}
.service-card:nth-child(3){
  border-color:#0066FF;
  box-shadow: 0 0 15px rgba(0,102,255,.3);
}
.service-card:hover{
  transform: translateY(-10px) scale(1.02);
  border-color: var(--c-accent);
  box-shadow: 0 20px 40px rgba(0,255,136,.3);
}

.service-image{ height:200px; overflow:hidden; }
.service-img{
  width:100%; height:100%; object-fit:cover;
  transition: transform var(--t-3) var(--easing);
}
.service-card:hover .service-img{ transform: scale(1.1); }

.service-content{ padding:2rem; text-align:center; }
.service-card h3{
  font-size:1.25rem; margin-bottom:1rem; color:#fff;
}
.service-card p{ color: var(--c-muted); }

/* =====================
   Guiding Principles
   ===================== */

.guiding-principles{
  background: linear-gradient(135deg, var(--c-bg-1), var(--c-bg-2));
  padding:6rem 0;
  position:relative;
}

.principles-content{
  position:relative; display:flex; flex-direction:column; align-items:center;
}
.principles-background{
  position:absolute; inset:0; z-index:1; opacity:.3;
}
.principles-bg-img{
  width:100%; height:100%; object-fit:cover; object-position:center;
}

.principles-list{
  position:relative; z-index:2; max-width:800px; width:100%;
  background: rgba(0,0,0,.4);
  padding:3rem; border-radius:var(--radius);
  backdrop-filter: blur(5px);
}
.principle-item{
  display:flex; align-items:flex-start; margin-bottom:2rem;
  opacity:0; transform:translateY(20px);
  animation: fadeInUpKF var(--t-6) ease-out forwards;
}
.principle-item:nth-child(1){ animation-delay: .1s; }
.principle-item:nth-child(2){ animation-delay: .2s; }
.principle-item:nth-child(3){ animation-delay: .3s; }
.principle-item:nth-child(4){ animation-delay: .4s; }
.principle-item:nth-child(5){ animation-delay: .5s; }

.principle-checkmark{
  color: var(--c-accent);
  font-size:1.5rem; font-weight:bold;
  margin-right:1rem; margin-top:.2rem;
}

.principle-text{
  color:#fff; font-size:1.125rem; line-height:1.5;
}
.principle-text strong{
  color: var(--c-accent);
  font-weight:600; font-size:1.2rem; letter-spacing:.5px; display:block; margin-bottom:.5rem;
}

/* Subtle animated grid */
.grid-background{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(50,255,126,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(50,255,126,.03) 1px, transparent 1px);
  background-size:50px 50px;
  animation: gridMove 20s linear infinite;
  pointer-events:none;
}

/* ===============
   Final CTA / Foo
   =============== */

.final-cta{
  background: linear-gradient(135deg, #000, #2A2A2A);
  padding:3rem 0;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.final-cta::before{
  content:'';
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(0,255,136,.1) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,255,136,.1) 1px, transparent 1px);
  background-size:40px 40px;
  animation: gridMove 15s linear infinite;
  pointer-events:none;
  z-index:1;
}

.footer-content{
  display:flex; flex-direction:column; align-items:center; text-align:center;
  max-width:800px; margin:0 auto; gap:1rem;
}
.cta-headline{
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  color:#fff; font-weight:600; letter-spacing:.5px; text-transform:uppercase; margin:0;
}
.separator{ color: var(--c-accent); margin:0 .75rem; font-weight:300; opacity:.7; }

.footer-email{
  color: var(--c-muted);
  text-decoration:none; font-size:.95rem;
  transition: color var(--t-3) ease, opacity var(--t-3) ease;
  opacity:.7;
}
.footer-email:hover{ color: var(--c-accent); opacity:1; }

.cta-logo{
  max-width:120px; height:auto; opacity:.9;
  transition: opacity var(--t-3) ease;
}
.cta-logo:hover{ opacity:1; }

.footer-copyright{
  color: var(--c-muted); font-size:.8rem; opacity:.5;
}

.footer-links{
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 0.5rem 0;
}

.footer-link{
  color: var(--c-muted);
  font-size: .8rem;
  opacity: .5;
  text-decoration: none;
  transition: opacity var(--t-3) ease;
}

.footer-link:hover{
  opacity: .8;
}

.footer-separator{
  color: var(--c-muted);
  opacity: .5;
}

/* =====================
   Responsive Adjustments
   ===================== */

@media (max-width: 768px){
  .container{ padding:0 1rem; }

  .nav{ display:none; }
  .mobile-burger-container{ display:block; }

  .hero-content{ text-align:center; padding:0 1rem; }
  .hero-subtext{ max-width:100%; }
  .hero-image-overlay{ opacity:.2; }

  .philosophy-content{ padding:0 1rem; }
  .manifesto-text p{ font-size:1.125rem; margin-bottom:1.5rem; }
  .philosophy-highlight{ font-size:1.25rem; }
  .philosophy-visual{ height:300px; }

  .services-grid{ grid-template-columns:1fr; }

  .principles-content{ padding:2rem 0; }
  .principles-list{ padding:2rem; }
  .principle-item{ flex-direction:column; text-align:center; align-items:center; }
  .principle-checkmark{ margin-right:0; margin-bottom:.5rem; align-self:center; }
}

@media (max-width: 480px){
  .hero-headline,
  .section-headline,
  .cta-headline{ font-size:1.75rem; }

  .service-card{ padding:1.5rem; }
  .footer-content{ gap:.75rem; }
  .cta-headline{ font-size: clamp(1.25rem, 4vw, 2rem); }
  .separator{ margin:0 .5rem; }
  .footer-email{ font-size:.9rem; }
  .cta-logo{ max-width:100px; }
  .footer-copyright{ font-size:.75rem; }
}

/* =====================
   Terms & Conditions
   ===================== */

.terms-content {
  background: var(--c-bg-0);
  min-height: 100vh;
  padding-top: 100px; /* space for fixed header */
  padding-bottom: 3rem;
}

.terms-wrapper {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 2rem;
}

.terms-title {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 600;
  color: #fff;
  text-align: center;
  margin-bottom: 1rem;
  letter-spacing: 0.5px;
}

.terms-effective-date {
  color: var(--c-accent);
  text-align: center;
  font-size: 1rem;
  margin-bottom: 3rem;
  font-weight: 500;
}

.terms-section {
  margin-bottom: 2.5rem;
  padding: 1.5rem;
  background: rgba(13, 13, 13, 0.5);
  border-radius: var(--radius);
  border: 1px solid rgba(179, 179, 179, 0.1);
  backdrop-filter: blur(5px);
}

.terms-section h2 {
  color: var(--c-accent);
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 1rem;
  letter-spacing: 0.5px;
}

.terms-section p {
  color: var(--c-muted);
  line-height: 1.6;
  margin-bottom: 1rem;
  font-size: 1rem;
}

.terms-section p:last-child {
  margin-bottom: 0;
}

.terms-section strong {
  color: #fff;
  font-weight: 600;
}

.terms-section ul {
  margin: 1rem 0;
  padding-left: 1.5rem;
}

.terms-section li {
  color: var(--c-muted);
  line-height: 1.6;
  margin-bottom: 0.5rem;
}

.terms-divider {
  border: none;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--c-accent), transparent);
  margin: 4rem 0;
  opacity: 0.3;
}

.terms-footer {
  text-align: center;
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(179, 179, 179, 0.1);
}

.back-to-home {
  display: inline-block;
  color: var(--c-accent);
  text-decoration: none;
  font-weight: 500;
  padding: 0.75rem 1.5rem;
  border: 1px solid var(--c-accent);
  border-radius: 8px;
  transition: all var(--t-3) var(--easing);
  background: rgba(0, 255, 136, 0.1);
}

.back-to-home:hover {
  background: var(--c-accent);
  color: #000;
  transform: translateY(-2px);
  box-shadow: var(--shadow-accent-12);
}

/* Mobile adjustments for terms */
@media (max-width: 768px) {
  .terms-wrapper {
    padding: 0 1rem;
  }
  
  .terms-section {
    padding: 1rem;
    margin-bottom: 2rem;
  }
  
  .terms-section h2 {
    font-size: 1.25rem;
  }
  
  .terms-section p,
  .terms-section li {
    font-size: 0.95rem;
  }
  
  .terms-divider {
    margin: 3rem 0;
  }
}

@media (max-width: 480px) {
  .terms-title {
    font-size: 1.75rem;
  }
  
  .terms-effective-date {
    font-size: 0.9rem;
  }
  
  .terms-section {
    padding: 0.75rem;
  }
  
  .terms-section h2 {
    font-size: 1.125rem;
  }
  
  .terms-section p,
  .terms-section li {
    font-size: 0.9rem;
  }
}

/* =====================
   Solutions Page
   ===================== */

.product-info {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 2rem;
  max-width: 600px;
}

.info-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  background: rgba(0, 255, 136, 0.1);
  border: 1px solid rgba(0, 255, 136, 0.3);
  border-radius: 8px;
  backdrop-filter: blur(5px);
}

.info-icon {
  font-size: 1.25rem;
  flex-shrink: 0;
}

.info-text {
  color: var(--c-muted);
  font-size: 0.95rem;
  font-weight: 500;
}

.solution-content {
  max-width: 1000px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.solution-text {
  color: var(--c-muted);
  font-size: 1.125rem;
  line-height: 1.6;
}

.solution-text p {
  margin-bottom: 1.5rem;
}

.solution-text p:last-child {
  margin-bottom: 0;
}

.solution-visual {
  position: relative;
  height: 400px;
  width: 100%;
  max-width: 800px;
  margin: 2rem auto 0;
}

.solution-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius);
  transition: transform var(--t-3) var(--easing);
}

.solution-img:hover {
  transform: scale(1.05);
}

.pricing-tiers {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin: 2rem 0;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

.pricing-tier {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.5rem;
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid rgba(179, 179, 179, 0.2);
  border-radius: 12px;
  backdrop-filter: blur(5px);
  transition: all var(--t-3) var(--easing);
}

.pricing-tier:hover {
  border-color: var(--c-accent);
  background: rgba(0, 255, 136, 0.05);
  transform: translateY(-2px);
}

.tier-icon {
  font-size: 1.5rem;
  flex-shrink: 0;
}

.tier-plan {
  color: #fff;
  font-weight: 600;
  font-size: 1.1rem;
  flex: 1;
}

.tier-price {
  color: var(--c-accent);
  font-weight: 600;
  font-size: 1.1rem;
}

.built-by-content {
  max-width: 600px;
  margin: 0 auto 2rem;
  text-align: center;
}

.built-by-content p {
  color: var(--c-muted);
  font-size: 1.125rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
}

.built-by-content p:last-child {
  margin-bottom: 0;
}

.built-by-content .highlight-text {
  color: var(--c-accent);
  font-weight: 600;
  font-size: 1.25rem;
}

/* Active navigation state */
.nav-link.active,
.mobile-nav-link.active {
  color: var(--c-accent);
  position: relative;
}

.nav-link.active::after {
  content: '';
  position: absolute;
  bottom: -5px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--c-accent);
  border-radius: 1px;
}

/* Mobile adjustments for solutions */
@media (max-width: 768px) {
  .product-info {
    gap: 0.75rem;
  }
  
  .info-item {
    padding: 0.5rem 0.75rem;
    gap: 0.5rem;
  }
  
  .info-text {
    font-size: 0.9rem;
  }
  
  .solution-text {
    font-size: 1rem;
  }
  
  .pricing-tiers {
    gap: 0.75rem;
  }
  
  .pricing-tier {
    padding: 0.75rem 1rem;
    gap: 0.75rem;
  }
  
  .tier-plan,
  .tier-price {
    font-size: 1rem;
  }
  
  .built-by-content p {
    font-size: 1rem;
  }
  
  .built-by-content .highlight-text {
    font-size: 1.125rem;
  }
}

@media (max-width: 480px) {
  .info-item {
    flex-direction: column;
    text-align: center;
    gap: 0.25rem;
  }
  
  .pricing-tier {
    flex-direction: column;
    text-align: center;
    gap: 0.5rem;
  }
  
  .tier-plan {
    order: 1;
  }
  
  .tier-price {
    order: 2;
  }
  
  .tier-icon {
    order: 0;
  }
}
