/* Dark, modern styles */
:root{
  --jet-black: #0F0F12;
  --charcoal: #2B2E34;
  --soft-gray: #E6E7EA;
  --white: #FFFFFF;
  --crimson: #B11226;
  --accent: #ff6b6b;
  --accent-2: #b11226;
  --steel: #8A8F98;
  --card: var(--charcoal);
  --text: var(--jet-black);
  --muted: var(--steel);
  --glass: rgba(255,255,255,0.02);
}
*{box-sizing:border-box}
body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;background:var(--soft-gray);color:var(--text);margin:0;-webkit-font-smoothing:antialiased;line-height:1.6;min-height:100vh;position:relative}

/* Page background layers */
body::before{
  /* subtle, professional geometric accents */
  content:"";position:fixed;inset:0;pointer-events:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1600 900' preserveAspectRatio='xMidYMid slice'><defs><linearGradient id='gA' x1='0' x2='1'><stop offset='0' stop-color='%23ff5c5c' stop-opacity='0.14'/><stop offset='1' stop-color='%23ff9a9a' stop-opacity='0.03'/></linearGradient></defs><rect width='100%' height='100%' fill='transparent'/><polygon points='0,0 700,0 220,420' fill='url(%23gA)' opacity='0.14'/><polygon points='1600,900 980,900 1440,520' fill='url(%23gA)' opacity='0.08'/></svg>");background-repeat:no-repeat;background-size:cover;opacity:0.9;mix-blend-mode:overlay;z-index:0}
body::after{content:"";position:fixed;inset:0;pointer-events:none;background-image:radial-gradient(ellipse at 20% 10%, rgba(255,154,154,0.03) 0%, transparent 30%), radial-gradient(ellipse at 80% 80%, rgba(255,92,92,0.02) 0%, transparent 30%), radial-gradient(rgba(255,255,255,0.01) 1px, transparent 1px);background-size:cover,cover,14px 14px;opacity:0.6;mix-blend-mode:overlay;z-index:0}

.wrapper{max-width:1000px;margin:0 auto;padding:36px;position:relative;z-index:10}

/* Unified card style for sections */
.section-card{padding:20px;border-radius:12px;background:var(--card);border:1px solid rgba(0,0,0,0.08);box-shadow:0 10px 36px rgba(11,12,15,0.25);position:relative;color:var(--white)}
.section-card::before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:6px;border-top-left-radius:12px;border-bottom-left-radius:12px;background:linear-gradient(180deg,var(--crimson),rgba(177,18,38,0.6));box-shadow:0 8px 40px rgba(177,18,38,0.06)}

.site-header{position:sticky;top:20px;backdrop-filter:blur(6px);background:var(--charcoal);padding:10px 0;border-radius:8px;box-shadow:0 8px 28px rgba(0,0,0,0.6);z-index:40}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{width:64px;height:64px;flex:0 0 64px;border-radius:8px;object-fit:cover}
.brand h1{margin:0;font-size:1.125rem;font-weight:700;letter-spacing:0.2px;color:var(--white)}
.brand .tag{margin:2px 0 0;color:var(--steel);font-size:0.83rem} 
.contact-cta{display:flex;gap:10px;align-items:center}
.contact-cta a{color:var(--white);text-decoration:none;padding:10px 14px;border-radius:8px;border:1px solid transparent;transition:all .18s ease}
.contact-cta .phone{background:var(--crimson);color:var(--white);font-weight:600}
.contact-cta .email{border:1px solid rgba(255,255,255,0.04);color:var(--steel)}
.hero{margin:26px 0;padding:36px;border-radius:12px;background:var(--card);box-shadow:0 20px 50px rgba(11,12,15,0.08);display:flex;flex-direction:column;gap:18px;align-items:center;border:1px solid rgba(0,0,0,0.06);position:relative;overflow:hidden;color:var(--white);text-align:center}
.hero h2{margin:0;font-size:2.1rem}
.hero p{margin:0;color:var(--steel);max-width:64ch}
.hero-illustration{width:140px;height:140px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hero-illustration svg{width:100%;height:100%;filter:drop-shadow(0 12px 24px rgba(0,0,0,0.45));}

/* Photo used in hero to match clipboard proportions and placement */
.hero-illustration .hero-photo{width:100%;height:100%;object-fit:cover;object-position:center top;border-radius:8px;filter:drop-shadow(0 8px 16px rgba(0,0,0,0.35));display:block}
@media(min-width:880px){
  .hero{flex-direction:row;align-items:center;justify-content:space-between;gap:28px}
  .hero > div:first-child{flex:1;min-width:0;text-align:center}
  .hero p{max-width:50ch;margin:0 auto;line-height:1.5}
  .hero > div:first-child .cta{margin-top:16px}
  .hero-illustration{width:160px;height:160px;flex-shrink:0;align-self:center}
}

/* Improve contrast of the scheduling graphic */
.hero-illustration svg rect{fill:rgba(255,255,255,0.06) !important;stroke:rgba(255,255,255,0.14) !important}
.hero-illustration svg path{stroke:var(--accent) !important;fill:var(--accent) !important;opacity:1 !important}
.cta{display:inline-block;background:linear-gradient(90deg,var(--accent),var(--accent-2));color:var(--white);padding:12px 20px;border-radius:12px;text-decoration:none;font-weight:800;border:none;box-shadow:0 12px 36px rgba(0,0,0,0.18);transition:transform .14s ease,box-shadow .14s ease}
@media(max-width:879px){
  .hero .cta{margin:0 auto}
}
.cta:hover{transform:translateY(-3px);box-shadow:0 22px 56px rgba(0,0,0,0.22)}

/* subtle page background texture */
body::after{content:"";position:fixed;inset:0;pointer-events:none;background-image:radial-gradient(rgba(255,255,255,0.01) 1px, transparent 1px);background-size:18px 18px;opacity:0.6;mix-blend-mode:overlay}
.services{margin-top:22px;text-align:center;padding:22px;border-radius:12px;background:var(--card);border:1px solid rgba(0,0,0,0.08);box-shadow:0 12px 48px rgba(11,12,15,0.22);position:relative;overflow:hidden;color:var(--white)}
.services h3{font-size:1.6rem;margin-bottom:12px}
.services-list{display:grid;grid-template-columns:1fr;gap:8px;padding:0;margin:18px auto 0;max-width:880px;list-style:none;text-align:left}
.services-list li{padding:12px 0;border-bottom:1px dashed rgba(255,255,255,0.06);position:relative;padding-left:28px;color:var(--white);font-size:1rem}
.services-list li::before{content:"";width:10px;height:10px;border-radius:50%;background:var(--crimson);position:absolute;left:8px;top:50%;transform:translateY(-50%);box-shadow:0 6px 20px rgba(0,0,0,0.18)}
@media(min-width:880px){
  .services-list{grid-template-columns:repeat(2,minmax(240px,1fr));max-width:960px}
}

.about{margin-top:22px;padding:18px;border-radius:10px;background:var(--card);border:1px solid rgba(0,0,0,0.08);color:var(--white)}

.contact{margin-top:18px;padding:20px;border-radius:12px;background:var(--card);border:1px solid rgba(0,0,0,0.08);box-shadow:0 8px 30px rgba(11,12,15,0.18);color:var(--white)}

/* Contact form styles */
form#contact-form{display:block;margin-top:12px}
.form-grid{display:grid;grid-template-columns:1fr;gap:12px}
.form-row input,.form-row textarea{width:100%;padding:14px;border-radius:10px;border:1px solid rgba(0,0,0,0.08);background:var(--white);color:var(--jet-black);outline:none;box-shadow:inset 0 1px 0 rgba(0,0,0,0.04), 0 6px 20px rgba(11,12,15,0.06);transition:all .18s ease;font-size:0.98rem}
.form-row.full{grid-column:1/-1}
.form-row input::placeholder,.form-row textarea::placeholder{color:rgba(160,176,191,0.45)}
.form-row input:focus,.form-row textarea:focus{transform:translateY(-2px);border-color:var(--crimson);box-shadow:0 18px 40px rgba(177,18,38,0.12),inset 0 1px 0 rgba(255,255,255,0.03)}
.form-actions{display:flex;gap:12px;align-items:center;margin-top:10px}
.form-success{color:#b7f5e9}
.form-error{color:#ffd6d6}
.alt-contact{margin-top:12px;color:var(--muted)}
.visually-hidden{position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}

@media(min-width:880px){
  .hero{flex-direction:row;align-items:center;justify-content:space-between}
  .hero p{max-width:56%}
  .form-grid{grid-template-columns:1fr 1fr}
  .form-row.full{grid-column:1/-1}
}
.services .card{background:linear-gradient(180deg,rgba(255,255,255,0.015),transparent);padding:18px;border-radius:10px;border:1px solid rgba(255,255,255,0.03)}
.services h3,.about h3,.contact h3{margin-top:0}
.about{margin-top:22px;padding:18px;border-radius:10px;background:var(--card);border:1px solid rgba(0,0,0,0.08);color:var(--white)}
.contact{margin-top:18px;padding:18px;border-radius:12px;background:var(--card);border:1px solid rgba(0,0,0,0.08);color:var(--white)}
.contact-grid{display:grid;grid-template-columns:1fr;gap:18px}
.details{padding:18px;border-radius:10px;background:transparent}
.details p{margin:6px 0;color:var(--white)}
.details a{color:var(--white);text-decoration:underline;font-weight:600}
.details .muted{color:var(--muted);margin-top:8px}
.contact-form{padding:8px;border-radius:10px;background:linear-gradient(180deg,rgba(255,255,255,0.02),transparent);border:1px solid rgba(255,255,255,0.02)}
.form-banner{min-height:36px;padding:10px 12px;border-radius:8px;margin-bottom:10px;font-weight:600}
.form-banner.success{background:linear-gradient(90deg,rgba(90,180,110,0.06),rgba(144,238,144,0.03));color:#eafaf0;border:1px solid rgba(90,180,110,0.06)}
.form-banner.error{background:linear-gradient(90deg,rgba(255,100,100,0.04),rgba(255,160,160,0.02));color:#ffd6d6;border:1px solid rgba(255,80,80,0.06)}
.form-note{font-size:0.9rem;color:var(--muted)}

.form-actions .cta{padding:12px 22px;border-radius:12px;font-size:1rem}

/* Ensure CTA contrast on all ctas */
.cta{box-shadow:0 14px 40px rgba(177,18,38,0.12)}
.cta:hover{box-shadow:0 26px 60px rgba(177,18,38,0.16)}

@media(min-width:880px){
  .contact-grid{grid-template-columns:340px 1fr}
}
@media(min-width:880px){
  .hero{flex-direction:row;align-items:center;justify-content:space-between}
  .hero p{max-width:56%}
}