/*
Theme Name: Over40Thrive Luxury OS
Theme URI: https://over40thrive.com
Author: Over40Thrive
Description: A luxury wellness WordPress theme for Over40Thrive, Fasting Circle, Beauty Archetype, ThriverMind, and connected digital wellness brands.
Version: 1.0.0
License: GPLv2 or later
Text Domain: over40thrive-luxury-os
*/

:root{
  --ot-navy:#141b2d;
  --ot-sage:#718f7a;
  --ot-gold:#c9a45c;
  --ot-rose:#f8e7e4;
  --ot-cream:#fffaf1;
  --ot-ivory:#fffdf8;
  --ot-mint:#eef7f1;
  --ot-lav:#f1edff;
  --ot-text:#303030;
  --ot-muted:#6d6d6d;
  --ot-white:#ffffff;
  --ot-shadow:0 18px 45px rgba(20,27,45,.12);
  --ot-radius:28px;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family:Georgia,serif;
  background:linear-gradient(135deg,var(--ot-cream),var(--ot-rose),var(--ot-mint));
  color:var(--ot-text);
  line-height:1.6;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto}

.ot-site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,253,248,.86);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(201,164,92,.18);
}
.ot-header-inner{
  max-width:1220px;
  margin:auto;
  padding:16px 22px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
}
.ot-logo{
  font-weight:900;
  color:var(--ot-navy);
  font-size:22px;
}
.ot-logo span{color:var(--ot-gold)}
.ot-nav{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.ot-nav a{font-size:15px;color:var(--ot-navy);font-weight:700}
.ot-section{max-width:1220px;margin:auto;padding:80px 22px}
.ot-center{text-align:center}
.ot-eyebrow{color:var(--ot-gold);font-weight:900;text-transform:uppercase;letter-spacing:1.4px;font-size:13px}
.ot-h1{font-size:64px;line-height:1.02;color:var(--ot-white);margin:14px 0 24px}
.ot-h2{font-size:44px;line-height:1.12;color:var(--ot-navy);margin:12px 0 18px}
.ot-p{font-size:19px;color:var(--ot-muted);max-width:850px;margin:0 auto 26px}
.ot-btn{display:inline-block;padding:16px 30px;margin:8px;border-radius:999px;font-weight:900;box-shadow:var(--ot-shadow);transition:.25s ease}
.ot-btn:hover{transform:translateY(-3px)}
.ot-btn-gold{background:var(--ot-gold);color:#181818}
.ot-btn-light{background:rgba(255,255,255,.92);color:var(--ot-navy)}
.ot-btn-sage{background:var(--ot-sage);color:white}
.ot-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}
.ot-card{
  background:rgba(255,255,255,.86);
  border:1px solid rgba(255,255,255,.62);
  border-radius:var(--ot-radius);
  padding:28px;
  box-shadow:var(--ot-shadow);
  backdrop-filter:blur(18px);
  transition:.25s ease;
}
.ot-card:hover{transform:translateY(-6px)}
.ot-card h3{color:var(--ot-sage);font-size:23px;margin:0 0 12px}
.ot-icon{
  width:48px;height:48px;border-radius:16px;
  background:linear-gradient(135deg,var(--ot-gold),#f3dfad);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;margin-bottom:18px;
}
.ot-hero{
  position:relative;
  padding:120px 22px;
  background:
    radial-gradient(circle at top right,rgba(201,164,92,.38),transparent 35%),
    linear-gradient(135deg,rgba(20,27,45,.94),rgba(72,93,80,.86)),
    url('https://images.unsplash.com/photo-1544367567-0f2fcb009e0b?auto=format&fit=crop&w=1800&q=80');
  background-size:cover;background-position:center;color:white;
}
.ot-hero-inner{max-width:1080px;margin:auto;text-align:center}
.ot-hero-copy{font-size:22px;max-width:890px;margin:0 auto 34px;color:rgba(255,255,255,.92)}
.ot-price-pill{
  display:inline-flex;gap:10px;align-items:center;justify-content:center;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);
  padding:12px 20px;border-radius:999px;margin-top:20px;backdrop-filter:blur(14px);
}
.ot-price-pill strong{color:var(--ot-gold);font-size:22px}
.ot-dashboard{
  display:grid;
  grid-template-columns:280px 1fr;
  min-height:75vh;
  background:rgba(255,255,255,.5);
}
.ot-sidebar{
  background:var(--ot-navy);
  color:white;
  padding:28px 20px;
}
.ot-side-title{font-size:22px;color:var(--ot-gold);font-weight:900;margin-bottom:22px}
.ot-side-link{display:block;padding:12px 14px;border-radius:14px;margin:7px 0;background:rgba(255,255,255,.07)}
.ot-dashboard-main{padding:30px}
.ot-metric{font-size:42px;color:var(--ot-gold);font-weight:900}
.ot-progress{background:#eee;border-radius:30px;height:16px;overflow:hidden}
.ot-progress div{background:linear-gradient(90deg,var(--ot-sage),var(--ot-gold));height:100%}
.ot-footer{background:var(--ot-navy);color:white;text-align:center;padding:42px 20px}
.ot-footer a{color:var(--ot-gold);margin:0 10px}
.ot-page-content{max-width:1000px;margin:auto;padding:60px 22px;background:rgba(255,255,255,.75)}
.fade-up{animation:fadeUp .8s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

@media(max-width:850px){
  .ot-h1{font-size:42px}
  .ot-h2{font-size:34px}
  .ot-hero{padding:90px 18px}
  .ot-dashboard{grid-template-columns:1fr}
  .ot-header-inner{align-items:flex-start;flex-direction:column}
}
