/* ============================================================
   PianoSpeed — Cloudflare clone of the Squarespace design
   Palette + type extracted from live www.pianospeed.com
   ============================================================ */
:root{
  --navy:#102847;          /* SQSP "black" = brand navy            */
  --navy-deep:#0b1d34;
  --cream:#FAF8F4;         /* page background / banner             */
  --beige:#E5E1D8;         /* borders, soft dividers               */
  --ink:#1a1a1a;           /* body text                            */
  --white:#ffffff;
  --accent:#cfe6ff;        /* hsl(210.6,100%,90%) pale-blue accent */
  --maxw:1200px;
  --pad:clamp(20px,5vw,64px);
  --display:'Jost',-apple-system,BlinkMacSystemFont,'Helvetica Neue',Arial,sans-serif; /* ~ Halyard Display */
  --body:'Helvetica Neue',Helvetica,Arial,sans-serif;                                  /* ~ Clarkson        */
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,.display{font-family:var(--display);font-weight:500;line-height:1.08;letter-spacing:.01em}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.btn{
  display:inline-block;font-family:var(--display);font-weight:500;
  letter-spacing:.08em;text-transform:uppercase;font-size:.82rem;
  padding:15px 34px;border-radius:2px;border:1.5px solid var(--navy);
  background:var(--navy);color:var(--white);cursor:pointer;
  transition:.2s ease;
}
.btn:hover{background:transparent;color:var(--navy)}
.btn--ghost{background:transparent;color:var(--white);border-color:var(--white)}
.btn--ghost:hover{background:var(--white);color:var(--navy)}
.btn--lg{padding:18px 44px;font-size:.9rem}

/* ---------- promo banner ---------- */
.banner{
  background:var(--cream);color:var(--ink);
  border-bottom:1px solid var(--beige);
  font-family:var(--display);font-size:.92rem;
  text-align:center;padding:9px 16px;letter-spacing:.02em;
}
.banner b{font-weight:600}
.banner a{text-decoration:underline;text-underline-offset:3px;white-space:nowrap}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:900;
  background:var(--navy);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.site-header .wrap{display:flex;align-items:center;gap:28px;height:74px}
.logo img{height:30px;width:auto}
.nav{display:flex;align-items:center;gap:26px;margin-left:auto}
.nav a{
  font-family:var(--display);color:#dfe6f0;font-size:.86rem;
  letter-spacing:.04em;transition:color .15s;
}
.nav a:hover{color:var(--white)}
.nav .btn{margin-left:6px}
.nav-toggle{display:none;background:none;border:0;color:#fff;font-size:1.5rem;margin-left:auto;cursor:pointer}

/* ---------- hero ---------- */
.hero{
  position:relative;min-height:78vh;display:flex;align-items:center;
  color:var(--white);text-align:center;
  background:#0b1d34;
}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55}
.hero__inner{position:relative;max-width:760px;margin:0 auto;padding:90px var(--pad)}
.hero h1{font-size:clamp(2.1rem,5.4vw,3.7rem);margin-bottom:22px;text-transform:none}
.hero p{font-size:clamp(1.05rem,2.2vw,1.3rem);max-width:620px;margin:0 auto 34px;color:#eef2f7}

/* ---------- generic section ---------- */
.section{padding:clamp(56px,9vw,110px) 0}
.section--cream{background:var(--cream)}
.section--navy{background:var(--navy);color:var(--white)}
.section--beige{background:var(--beige)}
.eyebrow{
  font-family:var(--display);text-transform:uppercase;letter-spacing:.18em;
  font-size:.72rem;font-weight:600;color:#6b7686;margin-bottom:18px;
}
.section--navy .eyebrow{color:var(--accent)}
.lede h2{font-size:clamp(1.9rem,4vw,2.9rem);text-transform:uppercase;margin-bottom:26px}
.lede p{font-size:1.12rem;max-width:760px;color:#33414f}
.section--navy .lede p{color:#d6deea}
.lede .btn{margin-top:34px}

/* split intro */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,70px);align-items:center}
.split img{border-radius:3px;box-shadow:0 24px 60px rgba(16,40,71,.18);aspect-ratio:4/5;object-fit:cover}

/* gallery strip */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px}
.gallery img{aspect-ratio:1/1;object-fit:cover;border-radius:2px}

/* testimonial */
.quote{max-width:860px;margin:0 auto;text-align:center}
.quote blockquote{
  font-family:var(--display);font-weight:400;font-style:normal;
  font-size:clamp(1.25rem,2.6vw,1.7rem);line-height:1.4;color:var(--white)
}
.quote cite{display:block;margin-top:24px;font-style:normal;color:var(--accent);letter-spacing:.06em}
.stars{color:var(--accent);letter-spacing:4px;margin-bottom:20px}

/* feature row */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;margin-top:8px}
.feature h3{font-size:1.18rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}
.feature p{color:#33414f;font-size:1rem}
.feature .num{font-family:var(--display);font-size:2.4rem;color:var(--navy);opacity:.25;line-height:1}

/* ---------- footer ---------- */
.footer{background:var(--navy-deep);color:#c4cedb;padding:64px 0 40px;font-size:.92rem}
.footer__grid{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between;align-items:flex-start}
.footer img{height:26px;margin-bottom:18px}
.footer a{color:#c4cedb}
.footer a:hover{color:#fff}
.footer nav{display:flex;flex-wrap:wrap;gap:8px 22px;max-width:420px}
.footer .addr{line-height:1.7}
.footer .copy{margin-top:40px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);color:#8593a6;font-size:.82rem}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .nav{display:none}
  .nav-toggle{display:block}
  .split{grid-template-columns:1fr}
  .split img{aspect-ratio:16/10}
  .features{grid-template-columns:1fr;gap:26px}
  .gallery{grid-template-columns:repeat(2,1fr)}
}

/* ============================================================
   FULL-SITE additions: dropdown nav, page heroes, faq, areas
   ============================================================ */

/* dropdown menus in header */
.nav .menu{position:relative}
.nav .menu>span{font-family:var(--display);color:#dfe6f0;font-size:.86rem;letter-spacing:.04em;cursor:default;display:inline-flex;align-items:center;gap:5px}
.nav .menu>span::after{content:"▾";font-size:.7em;opacity:.7}
.nav .menu:hover>span{color:#fff}
.dropdown{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);
  background:#fff;border:1px solid var(--beige);border-radius:4px;
  box-shadow:0 30px 70px rgba(11,29,52,.22);padding:18px;
  display:grid;grid-auto-flow:column;grid-template-rows:repeat(7,auto);gap:4px 26px;
  opacity:0;visibility:hidden;transition:.18s ease;z-index:950;
}
.nav .menu:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown a{font-family:var(--body);color:var(--ink);font-size:.86rem;letter-spacing:0;padding:7px 12px;border-radius:3px;white-space:nowrap}
.dropdown a:hover{background:var(--cream);color:var(--navy)}
.dropdown a[aria-current]{color:var(--navy);font-weight:600}

/* page hero (smaller than home hero) */
.pagehero{position:relative;background:var(--navy);color:#fff;text-align:center;overflow:hidden}
.pagehero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.42}
.pagehero__inner{position:relative;max-width:820px;margin:0 auto;padding:clamp(64px,10vw,120px) var(--pad)}
.pagehero .crumb{font-family:var(--display);text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;color:var(--accent);margin-bottom:18px}
.pagehero h1{font-size:clamp(2rem,5vw,3.4rem);margin-bottom:18px}
.pagehero p{font-size:clamp(1.02rem,2.1vw,1.25rem);color:#e7edf4;max-width:640px;margin:0 auto 30px}

/* prose + bullets */
.prose p{font-size:1.1rem;color:#33414f;margin-bottom:18px}
.section--navy .prose p{color:#d6deea}
.checklist{list-style:none;margin:18px 0 0;display:grid;gap:12px}
.checklist li{position:relative;padding-left:32px;color:#33414f;font-size:1.04rem}
.checklist li::before{content:"";position:absolute;left:0;top:.12em;width:20px;height:20px;border-radius:50%;background:var(--navy);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/15px no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/15px no-repeat;}
.section--navy .checklist li{color:#d6deea}
.section--navy .checklist li::before{background:var(--accent)}

/* faq accordion */
.faq{max-width:840px;margin:0 auto}
.faq details{border-bottom:1px solid var(--beige);padding:6px 0}
.faq summary{font-family:var(--display);font-size:1.12rem;font-weight:500;color:var(--navy);cursor:pointer;list-style:none;padding:18px 36px 18px 0;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:16px;font-size:1.5rem;color:var(--navy);transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{padding:0 0 20px;color:#33414f;font-size:1.04rem;max-width:760px}

/* area band (location pages) */
.areaband{background:var(--accent);color:var(--navy);text-align:center;padding:clamp(40px,6vw,64px) 0}
.areaband .big{font-family:var(--display);font-size:clamp(1.6rem,4vw,2.4rem);margin-bottom:10px}
.areaband .day{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.1em}
.areaband .pc{display:inline-block;background:var(--navy);color:#fff;border-radius:3px;padding:4px 12px;margin:0 4px;font-family:var(--display);letter-spacing:.05em}

/* cta band */
.ctaband{background:var(--navy);color:#fff;text-align:center;padding:clamp(56px,8vw,90px) 0}
.ctaband h2{font-size:clamp(1.7rem,3.6vw,2.6rem);text-transform:uppercase;margin-bottom:16px}
.ctaband p{color:#d6deea;max-width:560px;margin:0 auto 30px;font-size:1.1rem}

/* schedule table */
.schedule-table{width:100%;border-collapse:collapse;font-size:.96rem;margin-top:10px}
.schedule-table th,.schedule-table td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--beige)}
.schedule-table th{font-family:var(--display);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;color:#6b7686}
.schedule-table tr:hover td{background:var(--cream)}
.schedule-table .pccell{font-family:var(--display);font-weight:600;color:var(--navy)}

/* contact grid */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact-card{background:#fff;border:1px solid var(--beige);border-radius:5px;padding:30px}
.contact-card h3{font-size:1.1rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:14px}
.contact-card a{color:var(--navy);font-weight:600}

/* related links */
.related{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.related a{font-family:var(--display);font-size:.84rem;letter-spacing:.03em;border:1px solid var(--beige);background:#fff;color:var(--navy);padding:9px 16px;border-radius:30px;transition:.15s}
.related a:hover{background:var(--navy);color:#fff;border-color:var(--navy)}

@media (max-width:860px){
  .contact-grid{grid-template-columns:1fr}
  .dropdown{grid-auto-flow:row;grid-template-rows:none}
}

/* ---------- Trustpilot trust line (real: 4.9/5, 77 reviews) ---------- */
.trustline{display:inline-flex;align-items:center;gap:9px;margin-top:22px;font-family:var(--display);font-size:.92rem;font-weight:500;letter-spacing:.02em;color:#fff;transition:opacity .15s}
.trustline:hover{opacity:.85}
.trustline .tl-stars{color:#00b67a;letter-spacing:2px;font-size:1rem}
.trustline strong{font-weight:700}
.ctaband .trustline,.section--navy .trustline{color:#eaf0f7}
.hero .trustline{color:#eef2f7}

/* ============================================================
   BLOG — index grid + article (AIspeed.online publishes here)
   ============================================================ */
.postgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.postcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--beige);border-radius:6px;overflow:hidden;transition:.18s ease;color:var(--ink)}
.postcard:hover{transform:translateY(-4px);box-shadow:0 24px 50px rgba(16,40,71,.16)}
.postcard__img{aspect-ratio:16/10;overflow:hidden}
.postcard__img img{width:100%;height:100%;object-fit:cover}
.postcard__body{padding:22px 22px 26px;display:flex;flex-direction:column;gap:8px}
.postcard__date{font-family:var(--display);text-transform:uppercase;letter-spacing:.12em;font-size:.68rem;color:#6b7686}
.postcard h3{font-size:1.2rem;line-height:1.2;color:var(--navy)}
.postcard p{color:#33414f;font-size:.96rem;flex:1}
.postcard__more{font-family:var(--display);font-weight:600;color:var(--navy);font-size:.86rem;margin-top:6px}

.postbody{max-width:760px;margin:0 auto}
.postbody h2{font-size:clamp(1.5rem,3vw,2rem);margin:34px 0 14px}
.postbody h3{font-size:1.25rem;margin:26px 0 10px}
.postbody p{font-size:1.12rem;color:#2b3744;margin-bottom:18px}
.postbody .postimg{border-radius:5px;margin:26px 0;box-shadow:0 18px 44px rgba(16,40,71,.14)}
.pullquote{border-left:3px solid var(--navy);padding:6px 0 6px 24px;margin:26px 0;font-family:var(--display);font-size:1.3rem;line-height:1.4;color:var(--navy)}
.pullquote cite{display:block;margin-top:10px;font-size:.9rem;font-style:normal;color:#6b7686}
.posttags{display:flex;flex-wrap:wrap;gap:8px;margin-top:30px}
.posttags .tag{font-family:var(--display);font-size:.74rem;letter-spacing:.04em;text-transform:uppercase;background:var(--beige);color:var(--navy);padding:5px 12px;border-radius:20px}

@media (max-width:860px){.postgrid{grid-template-columns:1fr}}
