/* Schedule Pro — shared site styles (refined-minimal direction).
   Single source of truth for every page. */

:root{
  --ink:#1a1a1a; --muted:#555; --line:#e2e2e2; --line2:#cfcfcf;
  --bg:#ffffff; --soft:#f6f6f6; --link:#1c4f8b; --accent:#1c4f8b;
  --accent-dark:#16406f; --good:#1f8a4c; --warn:#c9421f;
  --maxw:960px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0}
body{
  font-family:"Segoe UI",system-ui,-apple-system,Arial,sans-serif;
  background:var(--bg); color:var(--ink); line-height:1.6; font-size:15px;
}
a{color:var(--link); text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}

/* ---------- Header ---------- */
.site-head{
  position:sticky; top:0; z-index:50; background:rgba(255,255,255,0.92);
  backdrop-filter:saturate(150%) blur(6px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .25s ease, border-color .25s ease;
}
.site-head.is-stuck{box-shadow:0 2px 14px rgba(0,0,0,0.08)}
.site-head .wrap{
  display:flex; align-items:center; gap:14px; padding:12px 24px;
  max-width:1200px;            /* wider than the body so the long nav fits */
}
.brand{font-weight:600; font-size:16px; display:flex; align-items:center; gap:9px; white-space:nowrap; flex:0 0 auto}
.brand img{height:24px; width:auto; display:block; transition:transform .3s ease}
.brand:hover img{transform:rotate(-6deg) scale(1.08)}
.brand:hover{text-decoration:none; color:var(--ink)}

nav.main{display:flex; align-items:center; gap:16px; margin-left:6px; flex-wrap:nowrap}
nav.main a{
  color:var(--muted); font-size:14px; position:relative; padding-bottom:2px;
  white-space:nowrap;
}
nav.main a::after{
  content:""; position:absolute; left:0; bottom:0; height:2px; width:100%;
  background:var(--accent); transform:scaleX(0); transform-origin:left;
  transition:transform .25s ease;
}
nav.main a:hover{color:var(--ink); text-decoration:none}
nav.main a:hover::after{transform:scaleX(1)}
nav.main a.is-active{color:var(--ink)}
nav.main a.is-active::after{transform:scaleX(1)}

.head-cta{margin-left:auto; display:flex; align-items:center; gap:8px; flex:0 0 auto}
.head-cta .btn, .head-cta .btn-ghost{white-space:nowrap}

.hamburger{
  display:none; margin-left:auto; background:none; border:1px solid var(--line2);
  border-radius:6px; padding:6px 9px; cursor:pointer; line-height:0;
}
.hamburger span{display:block; width:18px; height:2px; background:var(--ink); margin:3px 0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block; background:var(--accent); color:#fff;
  padding:10px 18px; border-radius:6px; font-weight:600; font-size:14px;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover{
  text-decoration:none; background:var(--accent-dark); transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(28,79,139,0.28);
}
.btn-ghost{
  display:inline-block; padding:10px 16px; border-radius:6px; font-size:14px;
  border:1px solid var(--line2); color:var(--ink); font-weight:600;
  transition:border-color .2s ease, color .2s ease;
}
.btn-ghost:hover{border-color:var(--accent); color:var(--accent); text-decoration:none}
.btn-sm{padding:7px 13px; font-size:13px}
.ver-badge{
  display:inline-block; margin-left:7px; padding:1px 7px; border-radius:10px;
  background:rgba(255,255,255,0.22); font-size:12px; font-weight:600;
}

/* ---------- Headings / sections ---------- */
h1{font-size:28px; font-weight:600; margin:0 0 10px}
h2{font-size:18px; font-weight:600; margin:0 0 14px}
h3{font-size:15px; font-weight:600; margin:0 0 4px}
section{padding:38px 0; border-bottom:1px solid var(--line)}
.intro{padding-top:48px}
.intro p{color:var(--muted); max-width:680px; margin:0 0 18px}
.links a{margin-right:14px; font-size:14px}
.lead{color:var(--muted); max-width:720px}

/* Page header row (detail pages): title + manual button */
.page-head{
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:16px; flex-wrap:wrap; padding-top:46px;
}
.page-head .lead{margin:10px 0 0}

/* ---------- Feature grid (home Views) ---------- */
.grid{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:6px}
.feature{
  border:1px solid var(--line); border-radius:8px; padding:16px 18px; background:#fff;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  display:block; color:inherit;
}
a.feature:hover{text-decoration:none}
.feature:hover{
  transform:translateY(-3px); border-color:#cdd8e6;
  box-shadow:0 8px 22px rgba(0,0,0,0.07);
}
.feature p{margin:6px 0 0; color:var(--muted); font-size:14px}
.feature .more{display:inline-block; margin-top:10px; font-size:13px; color:var(--accent); font-weight:600}

/* ---------- Tables ---------- */
table{width:100%; border-collapse:collapse; font-size:14px; margin-top:6px}
th,td{padding:9px 12px; border:1px solid var(--line); text-align:center}
th:first-child,td:first-child{text-align:left}
thead th{background:var(--soft); font-weight:600}
tbody tr{transition:background .15s ease}
tbody tr:hover{background:#f3f7fc}

/* ---------- Plans ---------- */
.plans{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:6px}
.plan{
  border:1px solid var(--line); border-radius:8px; padding:18px; background:#fff;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.plan:hover{
  transform:translateY(-4px); border-color:#cdd8e6; box-shadow:0 10px 26px rgba(0,0,0,0.08);
}
.plan.is-featured{border-color:var(--accent); box-shadow:0 0 0 1px var(--accent) inset}
.plan h3{font-size:16px; margin-bottom:2px}
.plan .meta{color:var(--muted); font-size:13px; margin-bottom:12px}
.plan ul{list-style:none; margin:0; padding:0}
.plan li{font-size:14px; color:var(--ink); padding:5px 0; border-top:1px solid var(--line)}
.plan li:first-child{border-top:none}
.note{color:var(--muted); font-size:13px; margin-top:14px}

/* ---------- Screenshot / media ---------- */
.shot{
  display:block; width:100%; height:auto; border:1px solid var(--line);
  border-radius:8px; transition:transform .3s ease, box-shadow .3s ease;
}
.shot:hover{transform:scale(1.01); box-shadow:0 12px 30px rgba(0,0,0,0.10)}

.media-ph{
  display:flex; align-items:center; justify-content:center; text-align:center;
  width:100%; min-height:220px; border:1px dashed var(--line2); border-radius:8px;
  background:repeating-linear-gradient(45deg,#fafbfc,#fafbfc 12px,#f3f5f8 12px,#f3f5f8 24px);
  color:#8a98a8; font-size:13px; padding:18px;
}
.video-embed{position:relative; width:100%; padding-top:56.25%; border-radius:8px; overflow:hidden; border:1px solid var(--line)}
.video-embed iframe{position:absolute; inset:0; width:100%; height:100%; border:0}

/* ---------- Alternating feature blocks (detail pages) ---------- */
.fblocks{display:flex; flex-direction:column; gap:30px; margin-top:10px}
.fblock{
  display:grid; grid-template-columns:1fr 1fr; gap:24px; align-items:center;
}
.fblock.rev .fblock-media{order:2}
.fblock-media .media-ph{min-height:200px}
.fblock-text h3{font-size:16px; margin-bottom:6px}
.fblock-text p{margin:0 0 8px; color:var(--muted); font-size:14px}
.fblock-text .how{
  font-size:13px; color:var(--ink); background:var(--soft);
  border-left:3px solid var(--accent); border-radius:0 5px 5px 0; padding:7px 11px; margin-top:8px;
}
.fblock-text .how b{font-weight:600}

/* ---------- Changelog / roadmap ---------- */
.timeline{list-style:none; margin:8px 0 0; padding:0}
.timeline li{position:relative; padding:0 0 14px 22px; border-left:2px solid var(--line); margin-left:5px}
.timeline li::before{
  content:""; position:absolute; left:-7px; top:3px; width:12px; height:12px;
  border-radius:50%; background:#fff; border:2px solid var(--accent);
}
.timeline li:last-child{border-left-color:transparent}
.timeline h3{margin-bottom:2px}
.timeline p{margin:0; color:var(--muted); font-size:14px}
.roadmap{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:6px}
.road{border:1px solid var(--line); border-radius:8px; padding:14px 16px; background:#fff}
.road .tag{font-size:11px; text-transform:uppercase; letter-spacing:.04em; color:var(--accent); font-weight:700}
.road p{margin:4px 0 0; color:var(--muted); font-size:14px}

/* ---------- Reviews slider ---------- */
.reviews{position:relative; margin-top:8px}
.review-track{overflow:hidden}
.review-rail{display:flex; transition:transform .5s ease}
.review{flex:0 0 100%; padding:6px 4px}
.review .card{
  border:1px solid var(--line); border-radius:10px; padding:22px 24px; background:#fff;
  max-width:680px; margin:0 auto; text-align:center;
}
.stars{color:#f3a712; letter-spacing:2px; font-size:15px; margin-bottom:8px}
.review blockquote{margin:0 0 12px; font-size:16px; line-height:1.55}
.review .who{font-size:13px; color:var(--muted)}
.review-nav{display:flex; align-items:center; justify-content:center; gap:14px; margin-top:14px}
.review-nav button{
  background:none; border:1px solid var(--line2); border-radius:50%; width:32px; height:32px;
  cursor:pointer; color:var(--ink); font-size:15px; line-height:1; transition:border-color .2s, color .2s;
}
.review-nav button:hover{border-color:var(--accent); color:var(--accent)}
.dots{display:flex; gap:7px}
.dots button{width:9px; height:9px; padding:0; border-radius:50%; border:none; background:var(--line2); cursor:pointer}
.dots button.is-on{background:var(--accent)}
.reviews-cta{text-align:center; margin-top:18px}

/* ---------- Owner cards (contact) ---------- */
.owners{display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:6px}
.owner{border:1px solid var(--line); border-radius:10px; padding:20px; background:#fff;
  transition:transform .25s ease, box-shadow .25s ease}
.owner:hover{transform:translateY(-3px); box-shadow:0 10px 26px rgba(0,0,0,0.07)}
.owner .photo{
  width:96px; height:96px; border-radius:50%; margin-bottom:14px;
  display:flex; align-items:center; justify-content:center; text-align:center;
  background:repeating-linear-gradient(45deg,#fafbfc,#fafbfc 10px,#f1f4f8 10px,#f1f4f8 20px);
  border:1px dashed var(--line2); color:#9aa6b4; font-size:11px;
}
.owner h3{font-size:17px}
.owner .role{color:var(--accent); font-size:13px; font-weight:600; margin-bottom:8px}
.owner p{color:var(--muted); font-size:14px; margin:0 0 12px}
.owner .contact-row{font-size:14px; margin-top:4px}
.owner .contact-row .k{color:var(--muted); display:inline-block; width:62px}

.statement{max-width:720px; font-size:15px; color:var(--ink)}

/* ---------- Footer ---------- */
footer{padding:26px 0; color:var(--muted); font-size:13px}
.foot{display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px}

/* ---------- Animations ---------- */
.reveal{opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease}
.reveal.is-visible{opacity:1; transform:none}
.intro h1, .intro p, .intro .links,
.page-head h1, .page-head .lead, .page-head .manual-btn{opacity:0; animation:rise .7s ease forwards}
.intro p, .page-head .lead{animation-delay:.12s}
.intro .links, .page-head .manual-btn{animation-delay:.24s}
@keyframes rise{from{opacity:0; transform:translateY(16px)} to{opacity:1; transform:none}}

/* ---------- Responsive ---------- */
@media(max-width:1100px){
  /* Brand + hamburger on the first row; nav and CTAs wrap to full-width rows
     below, stacked (no overlap), shown only when the menu is open. */
  .site-head .wrap{flex-wrap:wrap; row-gap:0}
  .hamburger{display:block; margin-left:auto; order:2}
  nav.main, .head-cta{
    display:none; flex-basis:100%; order:3;
    flex-direction:column; align-items:flex-start; gap:0; margin:0;
  }
  .site-head.menu-open nav.main, .site-head.menu-open .head-cta{display:flex}
  nav.main{padding-top:6px; border-top:1px solid var(--line); margin-top:6px}
  nav.main a{padding:10px 0; width:100%}
  .head-cta{padding:4px 0 8px}
  .head-cta .btn, .head-cta .btn-ghost{width:100%; text-align:center}
}
@media(max-width:680px){
  .grid,.plans,.roadmap,.owners{grid-template-columns:1fr}
  .fblock{grid-template-columns:1fr}
  .fblock.rev .fblock-media{order:0}
  .page-head{flex-direction:column}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{animation:none !important; transition:none !important}
  .reveal{opacity:1; transform:none}
  .review-rail{transition:none !important}
}
