:root {
  --ink: #1c1814;
  --muted: #756d64;
  --cream: #f7f3ed;
  --paper: #fffdf9;
  --peach: #e98f70;
  --peach-dark: #d97657;
  --sage: #8eaa91;
  --line: #e9e2d9;
  --shadow: 0 20px 60px rgba(58, 43, 31, .1);
}
* { box-sizing: border-box; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: "DM Sans", sans-serif; }
button, input { font: inherit; }
button { cursor: pointer; }
.ambient { position: fixed; z-index: -1; border-radius: 50%; filter: blur(10px); opacity: .5; }
.ambient-one { width: 380px; height: 380px; background: #f9ddd2; right: -180px; top: 120px; }
.ambient-two { width: 300px; height: 300px; background: #e3ece1; left: -160px; top: 700px; }
.site-header { height: 80px; display: flex; align-items: center; justify-content: space-between; padding: 0 4vw; border-bottom: 1px solid rgba(233,226,217,.7); background: rgba(255,253,249,.86); backdrop-filter: blur(16px); position: sticky; top: 0; z-index: 30; }
.brand { display: flex; align-items: center; gap: 9px; color: var(--ink); text-decoration: none; font-size: 21px; font-weight: 500; letter-spacing: -.8px; }
.brand b { font-weight: 700; color: var(--peach-dark); }
.brand-mark { display: grid; place-items: center; width: 31px; height: 31px; border-radius: 50% 50% 46% 54%; color: white; background: var(--peach); font-family: Georgia, serif; font-size: 23px; font-style: italic; }
.desktop-nav { display: flex; gap: 36px; }
.desktop-nav a { position: relative; color: var(--muted); text-decoration: none; font-size: 14px; font-weight: 600; }
.desktop-nav a.active, .desktop-nav a:hover { color: var(--ink); }
.desktop-nav a.active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -29px; height: 2px; background: var(--peach); }
.header-actions { display: flex; align-items: center; gap: 14px; }
.text-button, .back-button { border: 0; background: transparent; color: var(--ink); font-weight: 600; }
.primary-button { border: 0; border-radius: 13px; padding: 14px 21px; color: white; background: var(--ink); font-weight: 700; box-shadow: 0 8px 20px rgba(28,24,20,.15); }
.primary-button:hover { transform: translateY(-1px); background: #332b25; }
.primary-button.small { padding: 11px 17px; font-size: 13px; }
.mobile-menu { display: none; border: 0; background: none; font-size: 22px; }
.view { display: none; }
.view.active { display: block; animation: fade .35s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; transform: none; } }
.section-shell { width: min(1180px, calc(100% - 48px)); margin-inline: auto; }
.hero { min-height: 650px; display: grid; grid-template-columns: 1.03fr .97fr; gap: 60px; align-items: center; padding-block: 64px 80px; }
.eyebrow { color: var(--peach-dark); font-size: 11px; text-transform: uppercase; letter-spacing: 2.1px; font-weight: 700; }
.hero h1 { max-width: 600px; margin: 16px 0 20px; font: 700 clamp(48px, 6vw, 78px)/.98 "Playfair Display", serif; letter-spacing: -3px; }
.hero h1 em { color: var(--peach-dark); font-weight: 600; }
.hero-copy > p { max-width: 540px; color: var(--muted); line-height: 1.7; }
.search-card { position: relative; z-index: 3; width: 680px; margin-top: 34px; display: grid; grid-template-columns: 1.4fr 1fr auto; align-items: end; padding: 12px; border: 1px solid var(--line); border-radius: 18px; background: white; box-shadow: var(--shadow); }
.search-card label { padding: 0 15px; border-right: 1px solid var(--line); }
.search-card label > span { font-size: 11px; font-weight: 700; }
.input-wrap { display: flex; align-items: center; gap: 5px; margin-top: 5px; color: var(--peach-dark); }
.input-wrap input { width: 100%; border: 0; outline: none; color: var(--muted); font-size: 13px; }
.search-button { height: 48px; }
.trust-row { display: flex; align-items: center; gap: 12px; margin-top: 24px; color: var(--muted); font-size: 11px; }
.trust-row p { margin-right: 15px; }
.avatar-stack { display: flex; }
.avatar-stack span { width: 29px; height: 29px; display: grid; place-items: center; margin-left: -7px; border: 2px solid white; border-radius: 50%; background: #e5d5c8; color: #705747; font-size: 8px; font-weight: bold; }
.avatar-stack span:first-child { margin-left: 0; }
.rating { color: #d09b3d; letter-spacing: 1px; }
.rating strong { color: var(--ink); letter-spacing: 0; }
.hero-visual { position: relative; }
.hero-photo { height: 530px; border-radius: 48% 48% 28px 28px; position: relative; background: linear-gradient(130deg, rgba(78,49,36,.08), rgba(229,180,156,.15)), url("https://images.unsplash.com/photo-1570172619644-dfd03ed5d881?auto=format&fit=crop&w=1000&q=85") center/cover; box-shadow: var(--shadow); }
.photo-overlay { position: absolute; inset: 0; border-radius: inherit; background: linear-gradient(to top, rgba(38,27,20,.26), transparent 50%); }
.photo-tag { position: absolute; top: 32px; right: -20px; padding: 10px 13px; border-radius: 20px; background: rgba(255,255,255,.9); font-size: 11px; font-weight: 600; box-shadow: var(--shadow); }
.photo-tag b { margin-left: 5px; color: var(--sage); }
.floating-appointment { position: absolute; left: -42px; right: 48px; bottom: 28px; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 13px; padding: 14px; border-radius: 16px; background: rgba(255,255,255,.93); box-shadow: var(--shadow); backdrop-filter: blur(10px); }
.date-tile { width: 52px; height: 52px; display: grid; place-items: center; padding: 5px; border-radius: 11px; color: white; background: var(--peach); }
.date-tile b { font-size: 18px; line-height: 1; }.date-tile span { font-size: 8px; letter-spacing: 1px; }
.floating-appointment div:nth-child(2) { display: flex; flex-direction: column; gap: 2px; }
.floating-appointment small, .floating-appointment span { color: var(--muted); font-size: 9px; }.floating-appointment strong { font-size: 13px; }
.hero-stamp { position: absolute; left: -67px; top: -12px; width: 94px; height: 94px; display: grid; place-content: center; text-align: center; border-radius: 50%; color: white; background: var(--ink); border: 4px solid var(--paper); transform: rotate(-9deg); box-shadow: var(--shadow); }
.hero-stamp span { font-size: 7px; letter-spacing: 1.8px; }.hero-stamp b { color: #f0a78d; font: 700 23px "Playfair Display"; }
.category-section, .spaces-section { padding-block: 70px; }
.section-heading { display: flex; align-items: end; justify-content: space-between; margin-bottom: 30px; }
.section-heading h2, .business-banner h2 { margin: 8px 0 0; font: 700 36px "Playfair Display"; letter-spacing: -1.2px; }
.text-arrow, .card-heading button { border: 0; background: none; font-weight: 700; font-size: 12px; }.text-arrow span { color: var(--peach); font-size: 18px; }
.category-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
.category-card { min-height: 144px; display: flex; flex-direction: column; justify-content: space-between; padding: 18px; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.7); transition: .25s ease; }
.category-card:hover { transform: translateY(-5px); border-color: #e8b8a7; box-shadow: var(--shadow); }
.category-card i { width: 43px; height: 43px; display: grid; place-items: center; border-radius: 50%; background: var(--cream); font-style: normal; font-size: 20px; }
.category-card strong { font: 600 15px "Playfair Display"; }.category-card span { color: var(--muted); font-size: 9px; }
.spaces-section { background: linear-gradient(to bottom, transparent, rgba(247,243,237,.8), transparent); }
.filter-pills { display: flex; gap: 7px; }
.filter-pills button { padding: 8px 12px; border: 1px solid var(--line); border-radius: 20px; background: white; color: var(--muted); font-size: 10px; font-weight: 600; }
.filter-pills button.active { color: white; background: var(--ink); border-color: var(--ink); }
.space-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.space-card { overflow: hidden; border: 1px solid var(--line); border-radius: 19px; background: white; transition: .25s; }
.space-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.space-image { height: 220px; position: relative; background-position: center; background-size: cover; }
.space-image button { position: absolute; top: 13px; right: 13px; width: 34px; height: 34px; border: 0; border-radius: 50%; background: rgba(255,255,255,.9); }
.space-image span { position: absolute; left: 13px; bottom: 13px; padding: 6px 9px; border-radius: 15px; background: rgba(255,255,255,.92); font-size: 9px; font-weight: 700; }
.space-content { padding: 17px; }
.space-content h3 { margin: 0 0 4px; font: 700 19px "Playfair Display"; }.space-content > span { color: var(--muted); font-size: 10px; }
.space-content p { display: flex; justify-content: space-between; margin: 15px 0 0; padding-top: 13px; border-top: 1px solid var(--line); font-size: 10px; color: var(--muted); }.space-content p b { color: var(--ink); }
.business-banner { margin-block: 70px 90px; min-height: 300px; display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 50px; overflow: hidden; padding: 48px 70px; border-radius: 28px; color: white; background: #1d2925; }
.eyebrow.light { color: #d8a48e; }.business-banner h2 { max-width: 470px; font-size: 42px; }.business-banner p { max-width: 450px; color: #b9c4bf; font-size: 12px; line-height: 1.6; }
.cream-button { padding: 13px 18px; border: 0; border-radius: 11px; background: #fff9ef; color: var(--ink); font-weight: 700; font-size: 11px; }
.mini-dashboard { padding: 17px; border: 1px solid rgba(255,255,255,.15); border-radius: 18px; background: rgba(255,255,255,.08); transform: rotate(3deg) translateY(40px); }
.mini-top { display: flex; gap: 5px; align-items: center; }.mini-top span { width: 6px; height: 6px; border-radius: 50%; background: #9cab9f; }.mini-top b { margin-left: auto; font-size: 9px; }
.mini-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 17px; }.mini-stats div { padding: 13px; border-radius: 10px; background: rgba(255,255,255,.09); }.mini-stats small { display: block; color: #aebbb5; font-size: 8px; }.mini-stats b { font-size: 19px; }.mini-stats em { margin-left: 5px; color: #a6d4b5; font-size: 8px; }
.mini-chart { height: 90px; display: flex; align-items: end; gap: 9px; margin-top: 14px; padding: 12px; border-radius: 10px; background: rgba(255,255,255,.05); }.mini-chart i { flex: 1; border-radius: 4px 4px 0 0; background: #d6957e; }.mini-chart i:nth-child(1){height:30%}.mini-chart i:nth-child(2){height:55%}.mini-chart i:nth-child(3){height:42%}.mini-chart i:nth-child(4){height:75%}.mini-chart i:nth-child(5){height:65%}.mini-chart i:nth-child(6){height:90%}.mini-chart i:nth-child(7){height:78%}

/* Booking */
.booking-layout { display: grid; grid-template-columns: 240px 1fr 280px; gap: 35px; padding-block: 35px 70px; align-items: start; }
.business-profile { position: sticky; top: 115px; font-size: 11px; color: var(--muted); }.back-button { padding: 0; margin-bottom: 20px; font-size: 10px; }
.profile-cover { height: 110px; border-radius: 15px; background: url("https://images.unsplash.com/photo-1560066984-138dadb4c035?auto=format&fit=crop&w=700&q=80") center/cover; }
.profile-avatar { width: 60px; height: 60px; display: grid; place-items: center; margin: -30px 0 12px 15px; position: relative; border: 3px solid white; border-radius: 50%; background: #dec2b3; color: white; font: 700 17px "Playfair Display"; }
.verified { color: var(--sage); font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; }.business-profile h2 { margin: 8px 0 0; color: var(--ink); font: 700 25px "Playfair Display"; }.profile-subtitle { margin: 4px 0 12px; font-size: 9px; text-transform: uppercase; letter-spacing: 1.5px; }
.profile-rating { display: flex; gap: 9px; align-items: center; margin-bottom: 14px; }.profile-rating strong { color: #bd8437; }.profile-rating span { font-size: 9px; }
.business-profile > p { line-height: 1.7; }.profile-details { margin: 18px 0; padding: 13px 0; border-block: 1px solid var(--line); }.profile-details p { display: flex; gap: 9px; color: var(--ink); }.profile-details i { color: var(--peach); font-style: normal; }.profile-details small { color: var(--muted); }
.profile-links { display: flex; gap: 6px; }.profile-links button { flex: 1; padding: 8px; border: 1px solid var(--line); border-radius: 8px; background: white; font-size: 9px; font-weight: 700; }
.booking-content { min-width: 0; }.booking-header { display: flex; justify-content: space-between; align-items: end; margin-bottom: 35px; }.booking-header h1 { margin: 7px 0 0; font: 700 40px "Playfair Display"; }
.step-meter { display: flex; gap: 4px; flex-wrap: wrap; width: 110px; }.step-meter span { flex: 1; height: 3px; background: var(--line); }.step-meter span.active { background: var(--peach); }.step-meter small { width: 100%; margin-top: 4px; color: var(--muted); font-size: 8px; text-align: right; }
.booking-step { display: none; }.booking-step.active { display: block; animation: fade .3s; }.booking-step h3 { margin: 0 0 15px; font-size: 13px; }
.service-list { display: grid; gap: 9px; }.service-option { display: grid; grid-template-columns: auto 1fr auto; gap: 13px; align-items: center; padding: 15px; border: 1px solid var(--line); border-radius: 13px; background: white; text-align: left; }.service-option:hover, .service-option.selected { border-color: var(--peach); box-shadow: 0 9px 25px rgba(80,51,38,.08); }.service-option i { width: 40px; height: 40px; display: grid; place-items: center; border-radius: 10px; background: var(--cream); font-style: normal; }.service-option div { display: flex; flex-direction: column; gap: 3px; }.service-option strong { font-size: 12px; }.service-option span { color: var(--muted); font-size: 9px; }.service-option b { font-size: 12px; }
.professional-list { display: flex; gap: 9px; margin-bottom: 25px; }.pro-option { flex: 1; padding: 13px; border: 1px solid var(--line); border-radius: 12px; background: white; }.pro-option.selected { border-color: var(--peach); background: #fff8f4; }.pro-option span { display: grid; place-items: center; width: 35px; height: 35px; margin: 0 auto 6px; border-radius: 50%; background: #e7d8ce; font-size: 9px; font-weight: 700; }.pro-option strong, .pro-option small { display: block; text-align: center; }.pro-option strong { font-size: 10px; }.pro-option small { color: var(--muted); font-size: 8px; margin-top: 3px; }
.date-row { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; margin-bottom: 20px; }.date-option { padding: 9px 4px; border: 1px solid var(--line); border-radius: 9px; background: white; }.date-option span, .date-option b { display: block; text-align: center; }.date-option span { color: var(--muted); font-size: 7px; text-transform: uppercase; }.date-option b { margin-top: 3px; font-size: 11px; }.date-option.selected { color: white; border-color: var(--ink); background: var(--ink); }.date-option.selected span { color: #d7cec7; }
.time-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 7px; }.time-option { padding: 10px; border: 1px solid var(--line); border-radius: 8px; background: white; font-size: 9px; }.time-option:hover, .time-option.selected { color: white; border-color: var(--peach); background: var(--peach); }.time-option:disabled { color: #c9c0b8; background: #f6f3ef; text-decoration: line-through; cursor: not-allowed; }
.booking-summary { position: sticky; top: 115px; min-height: 270px; padding: 22px; border: 1px solid var(--line); border-radius: 17px; background: white; box-shadow: var(--shadow); }.empty-summary { min-height: 190px; display: grid; place-content: center; text-align: center; color: var(--muted); font-size: 10px; }.empty-summary i { color: var(--peach); font-size: 28px; font-style: normal; }.hidden { display: none !important; }.summary-content { margin-top: 20px; }.summary-service { display: flex; gap: 10px; align-items: center; padding-bottom: 15px; border-bottom: 1px solid var(--line); }.summary-service > span { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 9px; background: var(--cream); }.summary-service div { display: flex; flex-direction: column; }.summary-service small, .summary-service em { color: var(--muted); font-size: 8px; }.summary-service strong { font-size: 11px; }.summary-line { display: flex; justify-content: space-between; gap: 10px; margin: 14px 0; font-size: 9px; }.summary-line span { color: var(--muted); }.summary-line b { text-align: right; }.summary-content hr { border: 0; border-top: 1px solid var(--line); }.summary-line.deposit { color: var(--peach-dark); }.full { width: 100%; margin-top: 10px; }.summary-note { display: block; margin-top: 9px; color: var(--muted); text-align: center; font-size: 7px; }
.confirmation-card { padding: 40px; border: 1px solid var(--line); border-radius: 18px; background: white; text-align: center; }.confirm-icon { width: 52px; height: 52px; display: grid; place-items: center; margin: auto; border-radius: 50%; color: white; background: var(--sage); font-size: 24px; }.confirmation-card h2 { font: 700 27px "Playfair Display"; }.confirmation-card p { color: var(--muted); font-size: 11px; }.confirmation-card #confirmation-details { margin-top: 25px; padding: 16px; border-radius: 12px; background: var(--cream); font-size: 11px; line-height: 2; }

/* Dashboard */
.dashboard-view.active { display: grid; grid-template-columns: 220px 1fr; min-height: calc(100vh - 80px); background: #f8f6f2; }
.dashboard-sidebar { position: sticky; top: 80px; height: calc(100vh - 80px); display: flex; flex-direction: column; padding: 25px 17px; color: white; background: #1b2421; }.light-brand { color: white; margin-bottom: 28px; }.workspace-switcher { display: flex; align-items: center; gap: 9px; padding: 10px; border: 1px solid rgba(255,255,255,.1); border-radius: 11px; background: rgba(255,255,255,.05); }.workspace-logo { width: 32px; height: 32px; display: grid; place-items: center; border-radius: 8px; background: #dba28b; font-size: 10px; font-weight: 700; }.workspace-switcher div:nth-child(2) { flex: 1; display: flex; flex-direction: column; }.workspace-switcher small { color: #95a49e; font-size: 7px; }.workspace-switcher strong { font-size: 10px; }
.dashboard-sidebar nav { display: grid; gap: 5px; margin-top: 25px; }.dashboard-sidebar button { display: flex; gap: 12px; align-items: center; padding: 11px 12px; border: 0; border-radius: 8px; color: #abb8b3; background: transparent; text-align: left; font-size: 10px; font-weight: 600; }.dashboard-sidebar button.active { color: white; background: rgba(255,255,255,.1); }.dashboard-sidebar button b { margin-left: auto; width: 18px; height: 18px; display: grid; place-items: center; border-radius: 50%; color: white; background: var(--peach); font-size: 7px; }.sidebar-bottom { margin-top: auto; }.user-chip { display: flex; align-items: center; gap: 8px; margin-top: 10px; padding-top: 15px; border-top: 1px solid rgba(255,255,255,.1); }.user-chip > span { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 50%; background: #775c4f; font-size: 8px; }.user-chip div { display: flex; flex-direction: column; flex: 1; }.user-chip strong { font-size: 9px; }.user-chip small { color: #8f9d98; font-size: 7px; }
.dashboard-main { min-width: 0; padding: 35px 40px 60px; }.dash-header { display: flex; justify-content: space-between; align-items: center; }.dash-header h1 { margin: 6px 0 2px; font: 700 30px "Playfair Display"; }.dash-header p { margin: 0; color: var(--muted); font-size: 10px; }.dash-actions { display: flex; gap: 8px; }.icon-button { position: relative; width: 40px; border: 1px solid var(--line); border-radius: 10px; background: white; }.icon-button b { position: absolute; top: 8px; right: 8px; width: 5px; height: 5px; border-radius: 50%; background: var(--peach); }
.dash-metrics { display: grid; grid-template-columns: repeat(4, 1fr); gap: 13px; margin: 30px 0 20px; }.dash-metrics article { padding: 17px; border: 1px solid var(--line); border-radius: 13px; background: white; }.dash-metrics article > div { display: flex; align-items: center; gap: 8px; }.metric-icon { width: 28px; height: 28px; display: grid; place-items: center; border-radius: 8px; font-size: 10px; }.metric-icon.warm { color: #bd674d; background: #fae9e2; }.metric-icon.green { color: #4e795d; background: #e4f1e7; }.metric-icon.pink { color: #b16a75; background: #f7e6e9; }.metric-icon.gold { color: #a77a2f; background: #f9efd9; }.dash-metrics small { color: var(--muted); font-size: 8px; }.dash-metrics strong { display: block; margin: 11px 0 3px; font: 700 23px "Playfair Display"; }.dash-metrics p { margin: 0; color: var(--muted); font-size: 7px; }.dash-metrics p b { color: #58906b; }
.dashboard-grid { display: grid; grid-template-columns: 1.65fr .8fr; gap: 17px; }.schedule-card, .team-card { padding: 19px; border: 1px solid var(--line); border-radius: 14px; background: white; }.card-heading { display: flex; justify-content: space-between; align-items: start; }.card-heading h2 { margin: 0; font: 700 17px "Playfair Display"; }.card-heading p { margin: 3px 0; color: var(--muted); font-size: 8px; }.card-heading button { color: var(--peach-dark); font-size: 8px; }.schedule-tabs { display: flex; gap: 17px; margin: 18px 0 9px; border-bottom: 1px solid var(--line); }.schedule-tabs button { padding: 0 0 9px; border: 0; background: none; color: var(--muted); font-size: 8px; }.schedule-tabs button.active { color: var(--ink); border-bottom: 2px solid var(--peach); }.schedule-tabs b { padding: 2px 4px; border-radius: 5px; background: var(--cream); font-size: 7px; }
.appointment { display: grid; grid-template-columns: 48px 3px 1fr auto; align-items: center; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--line); }.appointment:last-child { border-bottom: 0; }.appointment time { color: var(--muted); font-size: 8px; }.appointment > i { width: 3px; height: 38px; border-radius: 3px; background: var(--peach); }.appointment-info { display: flex; align-items: center; gap: 9px; }.appointment-info > span, .team-member > span { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 50%; background: #ead8cd; color: #765a4a; font-size: 7px; font-weight: 700; }.appointment-info div { display: flex; flex-direction: column; gap: 2px; }.appointment-info strong { font-size: 9px; }.appointment-info small { color: var(--muted); font-size: 7px; }.status { padding: 4px 7px; border-radius: 10px; color: #4f7b5e; background: #e8f4eb; font-size: 7px; font-style: normal; }.status.pending { color: #a47a3f; background: #faf0dc; }
.dash-side-column { display: grid; gap: 17px; }.team-member { display: flex; align-items: center; gap: 8px; padding: 11px 0; border-bottom: 1px solid var(--line); }.team-member:last-child { border: 0; }.team-member div { display: flex; flex: 1; flex-direction: column; }.team-member strong { font-size: 8px; }.team-member small { color: var(--muted); font-size: 7px; }.team-member b { font-size: 7px; color: var(--muted); }.plan-card { padding: 20px; border-radius: 14px; color: white; background: #23312c; }.plan-card span { color: #d99c83; font-size: 7px; font-weight: bold; letter-spacing: 1px; }.plan-card h3 { margin: 7px 0 13px; font: 600 15px "Playfair Display"; }.plan-card div { height: 4px; border-radius: 3px; background: rgba(255,255,255,.13); }.plan-card i { display: block; width: 60%; height: 100%; border-radius: inherit; background: var(--peach); }.plan-card p { color: #a8b5b0; font-size: 7px; line-height: 1.5; }.plan-card button { padding: 0; border: 0; color: white; background: none; font-size: 8px; font-weight: bold; }
.toast { position: fixed; right: 25px; bottom: 25px; z-index: 100; padding: 13px 18px; border-radius: 10px; color: white; background: var(--ink); box-shadow: var(--shadow); font-size: 11px; opacity: 0; transform: translateY(15px); pointer-events: none; transition: .3s; }.toast.show { opacity: 1; transform: none; }

@media (max-width: 1050px) {
  .hero { grid-template-columns: 1fr .8fr; gap: 30px; }.search-card { width: 620px; }.category-grid { grid-template-columns: repeat(3,1fr); }.booking-layout { grid-template-columns: 180px 1fr; }.booking-summary { position: static; grid-column: 2; }.dash-metrics { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 800px) {
  .site-header { height: 66px; }.desktop-nav, .header-actions { display: none; }.mobile-menu { display: block; }.section-shell { width: min(100% - 30px, 620px); }.hero { display: block; padding-block: 45px; }.hero h1 { font-size: 53px; }.search-card { width: 100%; grid-template-columns: 1fr; gap: 12px; }.search-card label { border-right: 0; border-bottom: 1px solid var(--line); padding-bottom: 10px; }.hero-visual { margin-top: 55px; }.hero-photo { height: 430px; }.hero-stamp { left: -8px; }.floating-appointment { left: 15px; right: 15px; }.category-grid, .space-grid { grid-template-columns: repeat(2,1fr); }.section-heading { display: block; }.filter-pills { margin-top: 15px; overflow-x: auto; }.business-banner { grid-template-columns: 1fr; padding: 35px; }.mini-dashboard { display: none; }
  .booking-layout { display: block; }.business-profile { position: static; margin-bottom: 35px; }.booking-summary { margin-top: 25px; }.dashboard-view.active { display: block; }.dashboard-sidebar { display: none; }.dashboard-main { padding: 25px 15px; }.dashboard-grid { grid-template-columns: 1fr; }.dash-header { align-items: start; }.dash-actions .icon-button { display: none; }
}
@media (max-width: 520px) {
  .hero h1 { font-size: 44px; letter-spacing: -2px; }.trust-row { flex-wrap: wrap; }.category-grid, .space-grid { grid-template-columns: 1fr; }.business-banner h2 { font-size: 34px; }.booking-header { display: block; }.step-meter { margin-top: 15px; }.professional-list { display: grid; grid-template-columns: repeat(2,1fr); }.date-row { overflow-x: auto; grid-template-columns: repeat(7, 54px); }.time-grid { grid-template-columns: repeat(3,1fr); }.dash-metrics { grid-template-columns: 1fr 1fr; gap: 8px; }.dash-metrics article { padding: 12px; }.dash-header h1 { font-size: 24px; }.dash-actions .primary-button { padding: 10px; font-size: 9px; }.appointment { grid-template-columns: 40px 3px 1fr; }.appointment .status { display: none; }
}
