.workshop-preview{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,520px);gap:24px;align-items:center;padding:42px clamp(18px,5vw,64px);background:#101010;color:#fff;border-top:1px solid #282828}.workshop-preview h2{font-size:clamp(28px,4vw,44px);line-height:1.05;margin:0 0 12px}.workshop-preview p{color:#d7d7d7;line-height:1.55;max-width:720px}.workshop-preview-grid{display:grid;grid-template-columns:1fr;gap:10px}.workshop-preview-grid article{background:#191919;border:1px solid #2f2f2f;border-radius:8px;padding:16px}.workshop-preview-grid strong{display:block;color:var(--yellow);margin-bottom:5px}.workshop-preview-grid span{color:#d0d0d0;font-size:14px}
.dashboard-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:16px;margin-top:16px}.dashboard-focus{min-height:260px;background:linear-gradient(145deg,#fff,#fffdf6)}.insight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:16px}.insight-grid article{border:1px solid #ede4c9;background:#fff;border-radius:8px;padding:14px}.insight-grid strong{display:block;font-size:30px;color:#111}.insight-grid span{font-weight:900}.insight-grid p{margin:5px 0 0;color:#6e6a5e;font-size:13px}.next-actions{background:#111;color:#fff;border-color:#2a2a2a}.next-actions .panel-title p{color:#bbb}.action-stack{display:grid;gap:10px}.action-item{text-align:left;border:1px solid #343434;background:#191919;color:#fff;border-radius:8px;padding:13px;cursor:pointer}.action-item strong{display:block;color:var(--yellow);margin-bottom:4px}.action-item span{color:#d0d0d0;font-size:13px;line-height:1.4}
.panel-title{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}.panel-title>span{display:grid;place-items:center;min-width:42px;height:36px;border-radius:8px;background:#111;color:var(--yellow);font-weight:1000}.panel-title .panel-icon{background:transparent;padding:0;min-width:42px;height:42px}.panel-title .panel-icon img{display:block;width:42px;height:42px;object-fit:contain}.feature-band article .feature-icon{display:grid;place-items:center;min-width:42px;height:42px;background:transparent;padding:0}.feature-band article .feature-icon img{display:block;width:42px;height:42px;object-fit:contain}.panel-title h3{margin:0 0 3px}.panel-title p{margin:0;color:#6e6a5e;font-size:13px}.process-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}.process-strip div{display:flex;align-items:center;gap:12px;background:#111;color:#fff;border-radius:8px;padding:13px;border:1px solid #282828}.process-strip span{display:grid;place-items:center;width:32px;height:32px;border-radius:8px;background:var(--yellow);color:#080808;font-weight:1000}.process-strip strong{display:block}.process-strip small{display:block;color:#bbb;margin-top:2px}.add-vehicle-layout{grid-template-columns:360px 1fr}.upload-panel{background:linear-gradient(180deg,#fff,#fffaf0)}.upload-tips{margin-top:14px;background:#111;color:#fff;border-radius:8px;padding:14px}.upload-tips ul{margin:8px 0 0;padding-left:18px;color:#ddd;font-size:13px;line-height:1.5}
/* ---- Profile redesign (C7–C13) ---- */
.profile-identity{display:flex;align-items:flex-start;gap:16px;background:linear-gradient(135deg,#0f0f0f,#1d1d1d);color:#fff;border:1px solid #2a2a2a;border-radius:14px;padding:18px 20px;margin-bottom:14px;box-shadow:0 14px 32px #00000022}
.profile-avatar-block{display:flex;flex-direction:column;align-items:center;gap:10px;flex-shrink:0}
.profile-avatar-stack{position:relative;width:72px;height:72px}
.profile-avatar-stack .profile-avatar{position:absolute;inset:0;width:72px;height:72px}
.profile-avatar-photo{object-fit:cover;background:#fff}
.profile-avatar-actions{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;max-width:120px}
.profile-avatar-actions .btn{min-height:34px;padding:6px 10px;font-size:12px}
.profile-identity-copy{flex:1;min-width:0}
.profile-identity-copy h3{margin:0 0 4px;font-size:22px;color:#fff}
.profile-identity-copy .meta{margin:0;color:#cfcfcf;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.profile-identity-actions{flex-shrink:0;display:flex;gap:8px}
.profile-avatar-circle{display:grid;place-items:center;width:72px;height:72px;border-radius:50%;background:linear-gradient(145deg,var(--yellow),#f4b400);color:#080808;font-size:28px;font-weight:1000;border:2px solid #ffffff14;flex-shrink:0}
.profile-readiness{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin-bottom:16px;box-shadow:0 8px 22px #0000000a}
.profile-readiness-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:12px}
.profile-readiness-pct{font-size:34px;font-weight:1000;color:#111;line-height:1;letter-spacing:-.02em}
.profile-readiness-text{margin:6px 0 0;color:#5a5546;font-size:13.5px;line-height:1.45;max-width:540px}
.profile-qr-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin-bottom:16px;box-shadow:0 8px 22px #0000000a}
.profile-customer-number{margin:0 0 12px;font-size:15px;color:#333}
.profile-customer-number strong{color:#111;font-size:18px;letter-spacing:.04em}
.profile-qr-wrap{display:flex;justify-content:flex-start;margin:0 0 10px}
.profile-qr-wrap .qr{width:220px;height:220px;border-radius:12px;border:1px solid #e8e3d2;background:#fff;padding:10px;object-fit:contain}
.profile-qr-note{margin:0;color:#5a5546}
.profile-workshop-qr{display:flex;flex-wrap:wrap;gap:18px;align-items:flex-start}
.profile-workshop-qr-copy{flex:1;min-width:220px}
.profile-workshop-qr-copy .meta{margin:8px 0 0}
.profile-workshop-qr img{width:200px;height:200px;border-radius:12px;border:1px solid #333;background:#fff;padding:8px;object-fit:contain}
.profile-progress{position:relative;height:10px;border-radius:999px;background:#f0ebd6;overflow:hidden}
.profile-progress-fill{display:block;height:100%;width:calc(var(--p,0)*1%);background:linear-gradient(90deg,var(--yellow),#f4b400);border-radius:999px;transition:width .5s ease}
.profile-form-card{margin-bottom:14px}
.profile-card-head{margin:0 0 14px}
.profile-card-head h3{margin:0 0 4px;font-size:18px}
.profile-card-head .meta{margin:0;color:#6e6a5e;font-size:13px}
.profile-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px;margin-bottom:14px}
.profile-form-grid label{display:block;font-weight:800;font-size:13px;color:#3a3833;margin:0}
.profile-form-grid label.span-2{grid-column:1/-1}
.profile-form-grid input,.profile-form-grid select{margin-top:6px;font-size:15px;padding:11px 12px}
.profile-form-actions{display:flex;gap:10px;justify-content:flex-end}
.profile-collapse{padding:0;overflow:hidden;margin-top:14px}
.profile-collapse>summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;cursor:pointer;list-style:none;font-weight:900}
.profile-collapse>summary::-webkit-details-marker{display:none}
.profile-collapse>summary::after{content:"▾";font-size:14px;color:#6e6a5e;transition:transform .2s}
.profile-collapse[open]>summary::after{transform:rotate(180deg)}
.profile-collapse-title{font-size:16px}
.profile-collapse-meta{color:#6e6a5e;font-size:13px;font-weight:600}
.profile-collapse-body{padding:0 18px 18px;display:grid;gap:12px}
.profile-collapse-body label{margin:0;font-weight:800;font-size:13px}
.profile-collapse-body input{margin-top:6px}
.profile-collapse-body .btn{justify-self:flex-start}
@media(max-width:640px){
  .profile-identity{flex-wrap:wrap}
  .profile-identity-actions{width:100%;justify-content:flex-end}
  .profile-form-grid{grid-template-columns:1fr}
  .profile-form-grid label.span-2{grid-column:1}
  .profile-readiness-head{flex-direction:column-reverse;align-items:flex-start}
  .profile-readiness-pct{font-size:30px}
}
.garage-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin:0 0 16px;padding:14px 16px;background:#fff;border:1px solid var(--line);border-radius:8px}.garage-toolbar strong{display:block}.garage-toolbar span{display:block;color:#6e6a5e;font-size:13px;margin-top:3px}.vehicle-stats{display:flex;gap:8px;flex-wrap:wrap;margin-top:13px}.vehicle-stats span,.mini-stats span{display:inline-flex;border-radius:999px;background:#ffffff18;color:#f4f4f4;border:1px solid #ffffff24;padding:6px 9px;font-size:12px;font-weight:900}.profile-vehicle-row small{display:block;color:#8a8373;font-size:12px;margin-top:5px}.vehicle-profile-layout{grid-template-columns:360px 1fr}.vehicle-id-card{position:relative;overflow:hidden}.vehicle-id-card:after{content:"";position:absolute;right:-70px;bottom:-70px;width:190px;height:190px;border-radius:50%;background:#ffd21f16}.vehicle-timeline{min-height:360px}.mini-stats{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 14px}.mini-stats span{background:#f7f3e6;color:#292620;border-color:#eadfbe}.service-card{border-left:5px solid var(--yellow)}.empty-card{text-align:center;padding:28px}
.about-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:16px}.about-main h3{font-size:clamp(28px,4vw,42px);line-height:1.08;margin:0 0 12px}.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:18px}.contact-grid article{border:1px solid #ede4c9;border-radius:8px;padding:14px;background:#fffdf6}.contact-grid span{display:inline-flex;background:#111;color:var(--yellow);border-radius:7px;padding:5px 8px;font-weight:900;font-size:12px;margin-bottom:10px}.contact-grid strong{display:block}.contact-grid a{color:#111;text-decoration:none}.contact-grid a:hover{text-decoration:underline}.contact-grid p{margin:6px 0 0;color:#6e6a5e;font-size:13px}.map-panel{background:#111;color:#fff;border-color:#282828}.map-placeholder{display:grid;place-items:center;text-align:center;min-height:320px;border:1px dashed #555;border-radius:8px;background:linear-gradient(135deg,#171717,#252525);padding:20px;margin-bottom:12px}.map-placeholder span{display:grid;place-items:center;width:70px;height:70px;border-radius:18px;background:var(--yellow);color:#080808;font-weight:1000;margin-bottom:14px}.map-placeholder strong{font-size:22px}.map-placeholder p{color:#d0d0d0;line-height:1.45}.map-embed{overflow:hidden;border-radius:8px;border:1px solid #343434;background:#191919;margin-bottom:12px}.map-embed iframe{display:block;width:100%;height:320px}.map-action{display:flex;align-items:center;justify-content:center;text-decoration:none}
.auth-actions{display:flex;align-items:center;gap:8px}.nav [hidden]{display:none!important}
.profile-logout{margin:0}
.auth-actions #userMenu[hidden]{display:none!important}
@media(max-width:920px){.workshop-preview,.dashboard-layout,.profile-overview,.about-layout{grid-template-columns:1fr}.add-vehicle-layout,.vehicle-profile-layout,.profile-split{grid-template-columns:1fr}.insight-grid,.process-strip,.contact-grid,.about-pillars{grid-template-columns:1fr}.garage-toolbar{align-items:flex-start;flex-direction:column}}
/* Phase 3 */
.evidence-thumb{width:100%;max-height:200px;object-fit:cover;border-radius:10px;border:1px solid #e8e3d2}
.evidence-figure{margin:0;display:flex;flex-direction:column;gap:6px}
#serviceDetailPanel h4{margin:14px 0 6px}
/* Phase 3.2 — Notification center */
.topbar{z-index:1000!important}
.mobile-drawer{z-index:1100!important}
.notif-wrap{position:relative;display:inline-flex;z-index:1001}
.notif-bell{position:relative;display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:#ffffff14;border:1px solid #ffffff24;color:#fff;cursor:pointer}
.notif-bell:hover{background:#ffffff24}
.notif-badge{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 4px;border-radius:999px;background:var(--red);color:#fff;font-size:11px;font-weight:900;display:grid;place-items:center;border:2px solid #080808}
/* Notification panel — body-level so fixed positioning is not broken by header backdrop-filter */
.notif-panel[hidden]{display:none!important}
.notif-panel{position:fixed;top:64px;right:clamp(16px,4vw,48px);left:auto;width:min(360px,92vw);max-height:70vh;overflow:hidden;display:flex;flex-direction:column;background:#fff;color:#151515;border:1px solid #e2dcc6;border-radius:12px;box-shadow:0 18px 50px #00000040;z-index:1200;pointer-events:auto}
.topbar .auth-actions{position:relative;z-index:1210}
.notif-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px;border-bottom:1px solid #eee3c8}
.notif-head strong{font-size:15px;flex:1;min-width:0}
.notif-head-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.notif-close{display:grid;place-items:center;width:32px;height:32px;border:1px solid #e2dcc6;border-radius:8px;background:#f7f3e6;color:#333;font-size:22px;line-height:1;cursor:pointer;padding:0}
.notif-close:hover{background:#eee3c8}
.notif-tabs{display:flex;gap:6px;padding:10px 12px;border-bottom:1px solid #f0ead5;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.notif-tabs::-webkit-scrollbar{display:none}
.notif-tab{border:1px solid #e3dcc4;background:#fbf8ef;color:#5c574a;border-radius:999px;padding:5px 11px;font-size:12px;font-weight:800;cursor:pointer;white-space:nowrap;flex-shrink:0}
.notif-tab.active{background:#111;color:var(--yellow);border-color:#111}
.notif-list{overflow:auto;padding:6px;flex:1;min-height:0}
.notif-empty{padding:26px 14px;text-align:center;color:#8a8373;font-size:14px}
.notif-item{display:flex;gap:10px;width:100%;text-align:left;background:transparent;border:0;border-radius:9px;padding:11px 10px;cursor:pointer}
.notif-item:hover{background:#faf6ea}
.notif-item.unread{background:#fffbe9}
.notif-item.unread:hover{background:#fff6d6}
.notif-dot{margin-top:6px;min-width:9px;height:9px;border-radius:50%;background:var(--yellow2);flex-shrink:0}
.notif-body{display:flex;flex-direction:column;gap:3px;min-width:0;overflow:hidden}
.notif-title{font-weight:800;font-size:14px;line-height:1.25;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.notif-text{color:#6e6a5e;font-size:13px;line-height:1.35;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.notif-meta{display:flex;align-items:center;gap:7px;margin-top:3px;flex-wrap:wrap}
.notif-time{color:#9a9484;font-size:11px}
.notif-tag{font-size:10px;font-weight:900;border-radius:999px;padding:2px 7px;text-transform:uppercase;letter-spacing:.03em}
.notif-tag.email{background:#e7f0ff;color:#1d4ed8}
.notif-tag.reminder{background:#fff0d6;color:#a15c00}
.modal-overlay{z-index:1300!important}
/* Phase 3.2 — Mobile navigation drawer */
html,body{overflow-x:hidden;max-width:100%}
.menu-btn{align-items:center}
.mobile-drawer{box-shadow:0 18px 50px #00000055}
.mobile-drawer .drawer-nav{display:flex;flex-direction:column;gap:0}
.mobile-drawer a{display:block;color:#f4f4f4;text-decoration:none;padding:13px 4px;border-bottom:1px solid #ffffff14;font-weight:800;font-size:15px}
.mobile-drawer a:last-of-type{border-bottom:0}
.mobile-drawer a:hover,.mobile-drawer a.nav-active{color:var(--yellow)}
.mobile-drawer .drawer-auth{display:flex;flex-direction:column;gap:8px;margin-top:14px}
@media(max-width:840px){
  .auth-actions #loginBtn,.auth-actions #logoutBtn{display:none}
  .notification-panel{
    position:fixed;
    top:72px;
    right:12px;
    left:auto;
    width:min(92vw,380px);
    max-height:calc(100vh - 96px);
    overflow-y:auto;
    border-radius:16px;
    background:#151515;
    color:#f4f4f4;
    border:1px solid #333;
    box-shadow:0 18px 50px #00000080;
    z-index:1200;
  }
  .notification-panel .notif-head{border-bottom-color:#2a2a2a}
  .notification-panel .notif-head strong{color:#fff}
  .notification-panel .notif-close{border-color:#444;background:#222;color:#f4f4f4}
  .notification-panel .notif-close:hover{background:#333}
  .notification-panel .notif-tabs{border-bottom-color:#2a2a2a}
  .notification-panel .notif-tab{border-color:#444;background:#222;color:#ccc}
  .notification-panel .notif-tab.active{background:var(--yellow);color:#111;border-color:var(--yellow)}
  .notification-panel .notif-empty{color:#999}
  .notification-panel .notif-item:hover{background:#222}
  .notification-panel .notif-item.unread{background:#1f1a0a}
  .notification-panel .notif-item.unread:hover{background:#2a220e}
  .notification-panel .notif-title{color:#fff}
  .notification-panel .notif-text{color:#bbb}
  .notification-panel .notif-time{color:#888}
  .notification-panel .notif-tag.email{background:#1a2a4a;color:#7eb8ff}
  .notification-panel .notif-tag.reminder{background:#3a2a0a;color:#ffd21f}
  .notification-panel .btn.small.neutral{background:#222;color:#f4f4f4;border-color:#444}
}

/* Phase 4 — Booking modal wizard */
.lead-modal-overlay{position:fixed;inset:0;background:#000000bf;z-index:2000;display:grid;place-items:center;padding:16px}
.lead-modal{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px;max-width:440px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 18px 50px #00000040}
.lead-modal h3{margin:0 0 6px}
.booking-workshop-name{margin:0 0 14px;color:#666;font-weight:700}
.booking-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin:0 0 16px}
.booking-step{text-align:center;font-size:10px;font-weight:900;color:#999;padding:8px 2px;border-bottom:2px solid #eee;text-transform:uppercase;letter-spacing:.02em}
.booking-step.active{color:#111;border-color:var(--yellow)}
.booking-step.done{color:var(--green);border-color:var(--green)}
.booking-modal label{display:block;margin:0 0 12px;font-weight:800;font-size:13px}
.booking-modal select,.booking-modal input,.booking-modal textarea{width:100%;margin-top:6px;padding:12px;border:1px solid #d9d2bd;border-radius:8px;font:inherit;box-sizing:border-box}
.lead-modal .btn,.booking-modal .btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}
.lead-modal .btn.secondary,.booking-modal .btn.secondary{background:#f0ead5;color:#222;border:1px solid #d9d2bd;box-shadow:none}
.lead-modal .btn.secondary:hover,.booking-modal .btn.secondary:hover{background:#e8dfc4}
.booking-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid #eee3c8}
.booking-actions .btn,.booking-actions .btn.secondary{flex:1;min-width:100px}
.booking-actions-fallback .btn#bookNext{display:none!important}
.booking-actions-fallback{justify-content:stretch}
.booking-empty{text-align:left;padding:4px 0 0}
.booking-empty>p:first-child{text-align:center;font-size:16px;color:#222;margin-bottom:8px}
.booking-empty .meta{text-align:center;display:block;margin-bottom:14px}
.booking-review p{margin:0 0 12px;line-height:1.45}
.booking-review strong{font-size:12px;text-transform:uppercase;color:#777;letter-spacing:.03em}
.book-step-body{max-height:min(52vh,420px);overflow-y:auto;margin-bottom:4px}
.booking-fallback-actions{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.booking-fallback-actions .btn,.booking-fallback-actions .btn.secondary{width:100%}
@media(max-width:520px){
  .lead-modal{max-height:92vh;padding:16px}
  .booking-actions{flex-direction:column-reverse}
  .booking-actions .btn,.booking-actions .btn.secondary{width:100%;flex:none;min-width:0}
}
.notif-tag.booking{background:#1a2a1a;color:#1f8a5b}

/* ---- Profile bookings widget (C11) ---- */
.profile-booking-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:0 0 14px}
.profile-booking-metrics span{display:flex;flex-direction:column;align-items:flex-start;gap:2px;font-size:12px;color:#6e6a5e;background:#fffdf6;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-weight:700}
.profile-booking-metrics strong{font-size:20px;color:#111;font-weight:900;line-height:1}
.profile-booking-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-top:1px solid var(--line)}
.profile-booking-row:first-of-type{border-top:0;padding-top:4px}
.profile-booking-row strong{display:block;font-size:15px}
.profile-booking-row span{display:block;color:#6e6a5e;font-size:13px;margin-top:2px}
.profile-booking-row small{display:block;color:#8a8373;font-size:12px;margin-top:4px}
@media(max-width:640px){
  .profile-booking-metrics{grid-template-columns:1fr 1fr}
}

/* ---- User menu dropdown (C1, C4, C10) ---- */
.user-menu{position:relative;display:inline-flex}
.user-menu-btn{display:inline-flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border-radius:999px;background:#ffffff12;border:1px solid #ffffff24;color:#fff;cursor:pointer;min-height:40px}
.user-menu-btn:hover{background:#ffffff24}
.user-menu-avatar{display:grid;place-items:center;width:32px;height:32px;border-radius:50%;background:var(--yellow);color:#080808;font-weight:1000;font-size:13px}
.user-menu-caret{font-size:11px;color:#ddd}
.user-menu-panel{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:#fff;color:#151515;border:1px solid var(--line);border-radius:12px;box-shadow:0 18px 50px #00000035;padding:10px;z-index:1200}
.user-menu-panel[hidden]{display:none}
.user-menu-name{margin:4px 8px 8px;font-weight:900;font-size:13px;color:#6e6a5e;text-transform:uppercase;letter-spacing:.04em}
.user-menu-link,.user-menu-logout{display:block;width:100%;text-align:left;padding:10px 12px;border:0;background:transparent;color:#151515;font-weight:700;font-size:14px;text-decoration:none;border-radius:8px;cursor:pointer}
.user-menu-link:hover,.user-menu-logout:hover{background:#fbf5dc}
.user-menu-logout{color:var(--red);margin-top:6px;border-top:1px solid #f0ead0;padding-top:14px;border-radius:0 0 8px 8px}
@media(max-width:840px){.user-menu{display:none!important}}

/* ---- Mobile drawer sections ---- */
.mobile-drawer .drawer-section{padding:14px 0;border-bottom:1px solid #ffffff14}
.mobile-drawer .drawer-section:last-of-type{border-bottom:0}
.mobile-drawer .drawer-section-label{margin:0 0 6px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--yellow);font-weight:900}
.mobile-drawer .auth-section[hidden]{display:none}

/* ---- Notification panel polish (C17–C19) ---- */
.notif-empty{padding:30px 14px}
.notif-mark-all[disabled]{opacity:.45;cursor:not-allowed}

/* Enterprise mobile hardening — visual only, no behavior changes. */
@media(max-width:840px){
  .topbar,
  .hero,
  .hero-copy,
  .site-footer,
  .footer-grid,
  .workshop-preview,
  .network-wrap,
  .page{
    max-width:100%;
    min-width:0;
  }

  .hero,
  .site-footer,
  .workshop-preview,
  .network-wrap{
    overflow-x:hidden;
  }

  .hero-copy,
  .footer-grid,
  .site-footer *{
    overflow-wrap:anywhere;
  }

  .footer-grid{
    grid-template-columns:1fr!important;
  }

  .notif-wrap{
    width:40px;
    min-width:40px;
    flex:0 0 40px;
  }

  .notif-bell{
    width:40px;
    height:40px;
    overflow:hidden;
  }

  .notif-badge{
    top:2px;
    right:2px;
    min-width:16px;
    height:16px;
    padding:0 3px;
    border:1px solid #080808;
    font-size:10px;
  }
}
.notif-day-header{padding:10px 12px 6px;color:#9a9484;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}
.notif-day-header:first-child{padding-top:4px}

/* ---- Workshop directory premium polish (C25–C28) ---- */
.directory-filter-bar{position:sticky;top:60px;z-index:5;background:#080808f2;backdrop-filter:blur(12px);border:1px solid #2a2a2a;border-radius:14px;padding:14px 16px;margin:18px 0 22px;box-shadow:0 14px 40px #00000040;scroll-margin-top:72px}
#workshopSearchResults{scroll-margin-top:calc(72px + 220px)}
.filter-control-search{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;font-size:12px;color:#cfcfcf;font-weight:800}
.filter-control-search input{width:100%;background:#0d0d0d;color:#fff;border:1px solid #2e2e2e;border-radius:12px;padding:13px 14px 13px 42px;font-size:15px;min-height:48px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23b8b8b8' stroke-width='2.5' stroke-linecap='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='M20 20l-3.5-3.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:14px center}
.filter-control-search input::placeholder{color:#7a7a7a}
.filter-control-search input:focus{outline:2px solid var(--yellow);outline-offset:1px;border-color:#4a4100}
.directory-filter-controls{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr)) auto auto auto;gap:10px;align-items:end}
.filter-control{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#cfcfcf;font-weight:800}
.filter-control select{background:#0d0d0d;color:#fff;border:1px solid #2e2e2e;border-radius:10px;padding:11px 12px;font-size:14px;min-height:44px}
.filter-control select:focus{outline:2px solid var(--yellow);outline-offset:1px}
.filter-toggle{display:inline-flex;align-items:center;gap:8px;color:#cfcfcf;font-weight:800;font-size:13px;background:#141414;border:1px solid #2e2e2e;border-radius:999px;padding:11px 14px;min-height:44px;cursor:pointer;white-space:nowrap}
.filter-toggle input{width:auto;margin:0;accent-color:var(--yellow)}
.directory-filter-bar .btn,.directory-filter-bar .btn.secondary{min-height:44px;padding:11px 18px}
.filter-chip-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid #2a2a2a}
.filter-chip-row[hidden]{display:none}
.filter-chip{display:inline-flex;align-items:center;gap:6px;background:#1a1808;color:var(--yellow);border:1px solid #4a4100;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:800;cursor:pointer}
.filter-chip:hover{background:#2a2810}
.filter-chip-clear{background:transparent;border:1px solid #2a2a2a;color:#aaa}
.directory-section{margin:18px 0 0}
.directory-section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin:0 0 14px}
.directory-section-head h3{margin:0;font-size:22px;color:#fff;font-weight:900}
.directory-section-head .section-sub{margin:6px 0 0;color:#aaa;font-size:13px;max-width:540px}

@media(max-width:840px){
  .directory-filter-bar{position:relative;top:0;border-radius:12px;padding:12px}
  .directory-filter-controls{grid-template-columns:1fr 1fr;gap:8px}
  .directory-filter-controls .btn,.directory-filter-controls .btn.secondary,.filter-toggle{grid-column:1/-1}
  .directory-section-head{flex-direction:column;align-items:flex-start;gap:4px}
}
@media(max-width:520px){
  .directory-filter-controls{grid-template-columns:1fr}
}

/* ---- Workshop media: cover photo vs logo badge ---- */
.profile-cover{background:#151515 center/cover no-repeat;position:relative}
.profile-cover.wide{min-height:0}

/* ---- Workshop profile (customer-facing) mobile polish — see enterprise layout block below ---- */

/* ---- Booking wizard polish (C32–C35) ---- */
.booking-step-meta{display:block;margin:0 0 6px;font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:#999}
.booking-step-title{margin:0 0 14px;font-size:18px;font-weight:900;color:#111}
.booking-day-row{display:flex;gap:8px;overflow-x:auto;padding:4px 0 10px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.booking-day-row::-webkit-scrollbar{display:none}
.booking-day-chip{flex:0 0 auto;background:#f7f3e6;border:1px solid #e4dcc1;color:#3a3833;border-radius:12px;padding:8px 12px;font-weight:800;text-align:center;cursor:pointer;min-width:64px;font-size:12px;line-height:1.25}
.booking-day-chip strong{display:block;font-size:18px;color:#111;font-weight:1000;margin-bottom:2px}
.booking-day-chip.active{background:#111;color:var(--yellow);border-color:#111}
.booking-day-chip.active strong{color:var(--yellow)}
.booking-slot-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:8px;margin-top:8px}
.booking-slot-chip{background:#fff;border:1px solid #d9d2bd;color:#222;border-radius:10px;padding:10px 8px;font-weight:800;cursor:pointer;text-align:center;font-size:13px}
.booking-slot-chip:hover{border-color:#111}
.booking-slot-chip.active{background:#111;color:var(--yellow);border-color:#111}
.booking-slot-chip[disabled]{opacity:.4;cursor:not-allowed}
.booking-slot-cap{display:block;font-size:10px;font-weight:700;color:#777;margin-top:2px}
.booking-slot-chip.active .booking-slot-cap{color:#ddd}
.booking-review-list{display:grid;gap:10px}
.booking-review-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;background:#fffdf6;border:1px solid #efe7c8;border-radius:10px;padding:12px 14px}
.booking-review-row strong{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:#777;font-weight:900;margin-bottom:4px}
.booking-review-row p{margin:0;font-size:14px;color:#222;font-weight:700}
.booking-review-edit{flex-shrink:0;background:transparent;border:0;color:#1a4f9c;font-weight:900;cursor:pointer;font-size:12px;text-decoration:underline}
.booking-empty .booking-fallback-actions .btn{background:var(--yellow);color:#080808}
.booking-empty .booking-fallback-actions .btn.secondary{background:#f0ead5;color:#222;border:1px solid #d9d2bd}

/* ---- In-page anchor scrolling ---- */
.anchor-highlight{box-shadow:0 0 0 2px var(--yellow);transition:box-shadow .3s ease}
.profile-anchor-nav{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 16px;padding:6px;background:#fff;border:1px solid var(--line);border-radius:12px;position:sticky;top:calc(var(--topbar-height,72px) + 8px);z-index:6}
.profile-anchor-nav a{padding:8px 12px;border-radius:8px;text-decoration:none;font-weight:800;font-size:13px;color:#444;background:transparent;border:0;cursor:pointer}
.profile-anchor-nav a.nav-active,.profile-anchor-nav a[aria-current="true"]{background:#111;color:var(--yellow)}
.profile-anchor-block{scroll-margin-top:calc(var(--topbar-height,72px) + 24px)}
.profile-overview-block{display:grid;gap:0}
.profile-notifications{margin-top:14px}
.bookings-subhead{margin:0 0 12px;font-size:18px}
.bookings-anchor-block{margin-bottom:18px}
.report-download-block{margin-top:12px;padding-top:4px}

/* ---- Home hero: keep background subject visible ---- */
.hero{
  grid-template-columns:minmax(0,1fr);
  align-items:center;
  background:
    linear-gradient(90deg,#080808 0%,#080808eb 26%,#08080880 48%,#08080820 68%,transparent 82%),
    url('/assets/hero-gcc-auto.png') 82% 18%/cover no-repeat;
}
.hero-copy{
  max-width:min(620px,92vw);
  padding-bottom:0;
}
.hero-card{
  margin-top:18px;
  max-width:240px;
  width:100%;
  padding:11px 13px;
  align-self:start;
  background:#111c;
  backdrop-filter:blur(8px);
}
.hero-card strong{
  display:block;
  font-size:14px;
  line-height:1.25;
  margin:6px 0 4px;
}
.hero-card p{
  margin:0;
  font-size:12px;
  line-height:1.45;
}
.hero-card .status-dot{
  width:8px;
  height:8px;
  box-shadow:0 0 0 4px #ffd21f33;
}
@media (max-width:900px){
  .hero{
    min-height:680px;
    background-position:74% 12%;
  }
  .hero-card{max-width:220px}
}
@media (max-width:560px){
  .hero{
    background-position:center 8%;
    background-size:cover;
  }
  .hero-card{max-width:100%}
}

/* ---- PWA: fullscreen safe-area + standalone mode (Sprint F mobile) ---- */
/* Honor iPhone notch, dynamic island, and home indicator safe-area insets. */
@supports(padding:max(0px)){
  .topbar{padding-top:max(14px,env(safe-area-inset-top));padding-left:max(clamp(16px,4vw,48px),env(safe-area-inset-left));padding-right:max(clamp(16px,4vw,48px),env(safe-area-inset-right))}
  .mobile-drawer{padding-left:max(clamp(16px,4vw,48px),env(safe-area-inset-left));padding-right:max(clamp(16px,4vw,48px),env(safe-area-inset-right));padding-bottom:max(12px,env(safe-area-inset-bottom))}
  .site-footer{padding-left:max(clamp(16px,4vw,48px),env(safe-area-inset-left));padding-right:max(clamp(16px,4vw,48px),env(safe-area-inset-right));padding-bottom:max(28px,env(safe-area-inset-bottom))}
  .toast{bottom:max(18px,env(safe-area-inset-bottom));right:max(18px,env(safe-area-inset-right));left:max(18px,env(safe-area-inset-left));max-width:calc(100vw - max(18px,env(safe-area-inset-left)) - max(18px,env(safe-area-inset-right)))}
}
@media(min-width:560px){
  @supports(padding:max(0px)){
    .toast{left:auto}
  }
}

/* Installed (standalone) PWA: hide install banner forever, tighten chrome */
@media all and (display-mode:standalone){
  .pwa-install-banner{display:none!important}
  .topbar{position:sticky}
  /* Long-press text selection is rarely useful in an installed app shell */
  body{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}
  /* But inputs/textareas/content blocks should remain selectable */
  input,textarea,[contenteditable],.card,.panel,.about-main,.advisor-result,.history-row,.certificate,.workshop-profile-content{-webkit-user-select:text;user-select:text}
}

/* Mobile tap target hygiene: ensure interactive elements are >= 44x44 */
@media(hover:none) and (pointer:coarse){
  .btn,.btn.ghost,.btn.secondary,.btn.neutral,.btn.red{min-height:46px}
  .btn.small{min-height:40px}
  .nav a,.mobile-nav a,.footer-col a{padding-block:10px}
  /* Prevent iOS zoom-on-focus by ensuring inputs are >=16px */
  input,textarea,select{font-size:max(16px,1rem)}
  /* Larger tap targets for icon-only buttons */
  .notif-bell,.menu-btn,.user-menu-btn{min-width:44px;min-height:44px}
}

/* Smooth iOS scrolling + remove tap highlight color flash */
html{-webkit-tap-highlight-color:transparent}
body{-webkit-overflow-scrolling:touch}

/* ---- PWA install banner ---- */
.pwa-install-banner{position:fixed;left:max(12px,env(safe-area-inset-left));right:max(12px,env(safe-area-inset-right));bottom:max(12px,env(safe-area-inset-bottom));z-index:1500;display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;background:linear-gradient(135deg,#101010,#1a1a1a);color:#fff;border:1px solid #2a2a2a;box-shadow:0 18px 50px #00000080;max-width:540px;margin-inline:auto;animation:pwaInstallSlideUp .3s ease-out}
.pwa-install-banner[hidden]{display:none!important}
@keyframes pwaInstallSlideUp{from{transform:translateY(120%);opacity:0}to{transform:none;opacity:1}}
.pwa-install-icon{flex:0 0 44px;width:44px;height:44px;border-radius:10px;display:block}
.pwa-install-copy{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;line-height:1.3}
.pwa-install-copy strong{font-size:14px;font-weight:900;color:#fff}
.pwa-install-copy span{font-size:12.5px;color:#bdbdbd;font-weight:600}
.pwa-install-copy strong:lang(ar){font-family:inherit}
.pwa-install-actions{flex:0 0 auto;display:flex;align-items:center;gap:6px}
.pwa-install-actions .btn.small{min-height:38px;padding:8px 14px;font-size:13px;background:var(--yellow);color:#080808;font-weight:900;border-radius:8px}
.pwa-install-close{width:32px;height:32px;border-radius:50%;border:0;background:#0000;color:#bdbdbd;font-size:22px;line-height:1;cursor:pointer;display:grid;place-items:center;padding:0}
.pwa-install-close:hover{background:#ffffff14;color:#fff}
@media(max-width:420px){
  .pwa-install-banner{flex-wrap:wrap;gap:8px}
  .pwa-install-copy{flex-basis:calc(100% - 60px);order:2}
  .pwa-install-icon{order:1}
  .pwa-install-actions{order:3;width:100%;justify-content:flex-end;gap:8px}
  .pwa-install-actions .btn.small{flex:1}
}

/* ---- Hero trust strip (Sprint F polish) ---- */
.hero-trust-strip{list-style:none;margin:22px 0 0;padding:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;max-width:720px}
.hero-trust-strip li{background:#ffffff10;border:1px solid #ffffff20;border-radius:10px;padding:12px 14px;backdrop-filter:blur(4px)}
.hero-trust-strip strong{display:block;color:var(--yellow);font-size:13px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;margin-bottom:4px}
.hero-trust-strip span{display:block;color:#e8e8e8;font-size:13px;line-height:1.4;font-weight:600}
@media(max-width:840px){.hero-trust-strip{grid-template-columns:1fr;max-width:420px}}

/* ---- Customer dashboard "Add Vehicle" tile (Sprint F polish) ---- */
.metric.add-vehicle-tile{background:linear-gradient(140deg,#1a1808,#262204);border:1px solid #4a4100;color:#fff}
.metric.add-vehicle-tile strong{color:var(--yellow);font-size:46px;line-height:.9;font-weight:1000}
.metric.add-vehicle-tile span{color:#ffd21f;font-weight:900;text-transform:uppercase;letter-spacing:.04em;font-size:12px}
.metric.add-vehicle-tile:hover{transform:translateY(-2px);border-color:var(--yellow);box-shadow:0 14px 36px #00000040}

/* ---- Customer empty-card + process-strip readability (Sprint F polish) ---- */
.empty-card.is-light{background:#fffdf6;border:1px dashed #d9d2bd;color:#6e6a5e;border-radius:8px;padding:24px;text-align:center}
.empty-card.is-light h3{color:#222;margin:0 0 6px}
.process-strip>div{transition:background .15s,border-color .15s}
.process-strip>div:hover{background:#fffdf6;border-color:#e8dfc4}

/* ---- About: proof signals + map header (Sprint F polish) ---- */
.about-proof{list-style:none;margin:0 0 22px;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.about-proof li{display:flex;flex-direction:column;gap:4px;background:#fffdf6;border:1px solid #ede4c9;border-radius:8px;padding:12px 14px}
.about-proof strong{font-size:12px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:#111}
.about-proof strong::before{content:"✓";display:inline-block;color:var(--green);margin-right:6px;font-weight:1000}
.about-proof span{font-size:13px;line-height:1.45;color:#6e6a5e;font-weight:600}
@media(max-width:640px){.about-proof{grid-template-columns:1fr}}
.map-panel .map-eyebrow{margin:0 0 4px;color:var(--yellow);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.map-panel .map-title{margin:0 0 12px;color:#fff;font-size:18px;font-weight:900}
.map-panel .map-note{margin:12px 0;color:#bdbdbd;font-size:12px;line-height:1.5}
.contact-card{display:flex;align-items:flex-start;gap:12px}
.contact-card-icon{flex-shrink:0;width:40px;height:40px;display:grid;place-items:center;background:#111;color:var(--yellow);border-radius:8px}
.contact-card-icon svg{width:18px;height:18px}
.contact-card-body{min-width:0;flex:1}
.contact-card-body span{margin-bottom:10px}
.footer-contact-link{display:inline-flex;align-items:center;gap:8px}
.footer-contact-icon{width:16px;height:16px;flex-shrink:0;color:var(--yellow)}

/* ---- Site footer (Sprint F polish) ---- */
.site-footer{background:#070707;color:#cfcfcf;border-top:1px solid #1c1c1c;padding:48px clamp(16px,4vw,48px) 28px;margin-top:0}
.footer-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:32px 28px}
.footer-brand{display:flex;flex-direction:column;gap:12px;max-width:360px}
.footer-brand-link{display:inline-block;line-height:0}
.footer-logo{width:min(220px,80%);height:auto;display:block;filter:drop-shadow(0 8px 18px #0007)}
.footer-tagline{margin:0;color:#cfcfcf;font-size:14px;line-height:1.55}
.footer-badge{display:inline-flex;align-items:center;gap:8px;background:#141414;border:1px solid #2a2a2a;border-radius:999px;padding:7px 12px;color:var(--yellow);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.04em;width:max-content;max-width:100%}
.footer-badge-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--yellow);box-shadow:0 0 0 4px #ffd21f22}
.footer-col{display:flex;flex-direction:column;gap:8px}
.footer-col h4{margin:0 0 6px;color:#fff;font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:900}
.footer-col a{color:#cfcfcf;text-decoration:none;font-weight:700;font-size:14px;line-height:1.4;padding:2px 0}
.footer-col a:hover{color:var(--yellow)}
.footer-bottom{max-width:1280px;margin:36px auto 0;padding-top:18px;border-top:1px solid #1c1c1c;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#8a8a8a;font-size:12px}
.footer-bottom p{margin:0}
.footer-meta{color:#666}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:24px}.footer-brand{grid-column:1/-1;max-width:none}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;align-items:flex-start;text-align:left}}
@media print{.site-footer{display:none!important}}

/* Get-the-app CTA in primary nav */
.nav-app-cta{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;margin-left:6px;border-radius:999px;background:linear-gradient(135deg,#c9a227 0%,#e8be4d 100%);color:#11161c !important;font-weight:800;letter-spacing:.01em;box-shadow:0 6px 14px rgba(201,162,39,.28),0 2px 5px rgba(0,0,0,.18);transition:transform .15s ease,box-shadow .15s ease}
.nav-app-cta:hover{transform:translateY(-1px);box-shadow:0 10px 18px rgba(201,162,39,.36),0 3px 7px rgba(0,0,0,.22)}
.nav-app-cta::before{content:"";width:6px;height:6px;border-radius:50%;background:#11161c}
html[data-native] .nav-app-cta{display:none}
@media (max-width:780px){.nav-app-cta{display:none}}

/* White profile/login panels must use light form controls (page sets color-scheme:dark). */
#profile .panel,
#profile .profile-qr-card,
#profile .profile-readiness,
#login .panel.narrow {
  color-scheme: light;
  color: #151515;
}

#profile .profile-form-grid input,
#profile .profile-form-grid select,
#profile .profile-collapse-body input,
#profile .profile-collapse-body select,
#loginForm input,
#loginForm select {
  color: #151515;
  background: #fff;
  border: 1px solid #d9d2bd;
  -webkit-text-fill-color: #151515;
}

#profile .profile-form-grid input:disabled {
  color: #5a5546;
  background: #f3f0e6;
  -webkit-text-fill-color: #5a5546;
  opacity: 1;
}

#profile .profile-form-grid input::placeholder,
#profile .profile-collapse-body input::placeholder,
#loginForm input::placeholder {
  color: #8a8373;
  opacity: 1;
}

#profile .profile-form-grid select option,
#profile .profile-collapse-body select option {
  color: #151515;
  background: #fff;
}

#profile .profile-card-head h3,
#profile .profile-qr-card h3 {
  color: #111;
}

#profile .profile-card-head .meta,
#profile .profile-qr-note,
#profile .profile-customer-number {
  color: #5a5546;
}

#profile .profile-customer-number strong {
  color: #111;
}

/* Final enterprise mobile fit pass: keep content inside its own containers. */
@media(max-width:840px){
  .hero-copy{
    width:100%;
    max-width:100%;
    min-width:0;
  }

  .hero-logo-white{
    width:min(300px,82vw)!important;
    max-width:100%;
  }

  .hero-copy>*{
    max-width:100%;
  }

  .site-footer{
    width:100%;
    max-width:100%;
    overflow:hidden;
  }

  .footer-grid{
    width:100%;
    max-width:100%;
    min-width:0;
    grid-template-columns:minmax(0,1fr)!important;
    gap:22px;
  }

  .footer-grid>*,
  .footer-brand,
  .footer-col{
    min-width:0;
    max-width:100%;
  }

  .footer-badge{
    width:100%;
    max-width:100%;
    white-space:normal;
    border-radius:12px;
    align-items:flex-start;
  }

  .footer-col a,
  .footer-tagline{
    overflow-wrap:anywhere;
    word-break:normal;
  }
}

/* ---- Public page routing (home / workshops / about) ---- */
.home-directory-cta{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid #2f2f2f;
}
.page-head-dark{
  background:linear-gradient(180deg,#0c0c0c 0%,#151515 100%);
  color:#fff;
  padding:clamp(28px,6vw,56px) clamp(18px,5vw,64px) clamp(20px,4vw,36px);
  border-bottom:1px solid #2a2a2a;
}
.page-head-dark .eyebrow{color:var(--yellow)}
.page-head-dark h2{
  margin:0 0 10px;
  font-size:clamp(28px,4.5vw,42px);
  line-height:1.08;
  color:#fff;
}
.page-head-dark .page-lead{
  margin:0;
  max-width:720px;
  color:#d2d2d2;
  font-size:clamp(15px,2.2vw,17px);
  line-height:1.55;
}
#workshopsPage.workshop-directory-route{
  padding:0;
  background:#0b0b0b;
}
.workshop-network-page{
  padding-top:0;
  background:#0b0b0b;
}
.workshop-network-page .network-head-compact{
  padding:18px clamp(18px,5vw,64px) 0;
  text-align:left;
}
.workshop-network-page .network-head-compact .section-brand-logo{
  width:min(180px,42vw);
  height:auto;
}
.workshop-network-page .network-wrap{
  padding-top:8px;
}
@media (max-width:768px){
  .page-head-dark{
    padding-top:24px;
    padding-bottom:18px;
  }
  .home-directory-cta{
    flex-direction:column;
  }
  .home-directory-cta .btn{
    width:100%;
    justify-content:center;
  }
  .workshop-network-page .directory-filter-bar{
    position:sticky;
    top:calc(var(--topbar-height,72px) + 4px);
    z-index:4;
    background:#111;
    border-radius:12px;
    margin-inline:clamp(12px,3vw,18px);
    padding:12px;
    box-shadow:0 8px 24px #00000055;
  }
}

/* ---- Workshop profile: enterprise layout (2026-07-04) ---- */
.profile-page-wrap{
  background:#080808;
  min-height:70vh;
  padding-bottom:24px;
}
.profile-hero-card{
  margin-top:-36px;
  position:relative;
  z-index:2;
  border-radius:16px;
  padding:18px 18px 16px;
  border:1px solid #2a2a2a;
  background:linear-gradient(180deg,#141414,#101010);
}
.profile-eyebrow{
  margin:0 0 6px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#9a9a9a;
}
.profile-quick-facts{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.profile-fact-chip{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  background:#1c1c1c;
  border:1px solid #333;
  color:#ddd;
  font-size:12px;
  font-weight:700;
  text-decoration:none;
}
.profile-fact-link:hover{
  color:var(--yellow);
  border-color:#555;
}
.profile-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(260px,320px);
  gap:16px;
  margin-top:18px;
  align-items:start;
}
.profile-main,
.profile-aside{
  display:grid;
  gap:14px;
}
.profile-aside .profile-panel{
  margin:0;
}
.profile-hours-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:8px;
}
.profile-hours-list li{
  padding:8px 10px;
  border-radius:8px;
  background:#161616;
  border:1px solid #2a2a2a;
  font-size:13px;
  line-height:1.4;
  color:#ddd;
}
.profile-hours-text{
  margin:0;
  font-size:14px;
  line-height:1.5;
  color:#ccc;
  word-break:break-word;
}
.profile-gallery{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:10px;
}
.profile-gallery img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:10px;
  border:1px solid #333;
}
.profile-workshop-qr{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  text-align:center;
}
.profile-workshop-qr img{
  width:min(180px,100%);
  height:auto;
  border-radius:10px;
  background:#fff;
  padding:8px;
}
.profile-mobile-bar{
  display:none;
}
@media(max-width:840px){
  .profile-page-wrap{
    padding-bottom:calc(76px + env(safe-area-inset-bottom));
  }
  .profile-hero-card{
    margin-top:-24px;
    padding:14px;
    border-radius:14px;
  }
  .profile-hero{
    display:grid;
    grid-template-columns:72px 1fr;
    gap:12px;
    align-items:start;
  }
  .profile-logo-wrap{
    width:72px;
    height:72px;
  }
  .profile-hero-actions .profile-actions-primary,
  .profile-hero-actions .profile-actions-secondary{
    display:none;
  }
  .profile-layout{
    grid-template-columns:1fr;
    margin-top:14px;
  }
  .profile-aside{
    order:-1;
  }
  .profile-gallery{
    display:flex;
    gap:10px;
    overflow-x:auto;
    padding-bottom:4px;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
  }
  .profile-gallery img{
    flex:0 0 min(78vw,280px);
    scroll-snap-align:start;
  }
  .profile-mobile-bar{
    display:flex;
    gap:10px;
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    z-index:45;
    padding:10px 14px calc(10px + env(safe-area-inset-bottom));
    background:linear-gradient(180deg,transparent,#080808e6 24%,#080808 40%);
    backdrop-filter:blur(8px);
  }
  .profile-mobile-bar .btn{
    flex:1;
    min-height:48px;
    border-radius:12px;
    font-weight:900;
  }
  .workshop-profile-content .profile-cover.wide{
    max-height:min(38vh,260px);
  }
  .workshop-profile-content .profile-shell{
    padding:0 14px 20px;
    max-width:640px;
    margin:0 auto;
  }
}
@media(min-width:841px){
  .profile-shell{
    max-width:1040px;
  }
  .profile-hero{
    display:flex;
    gap:16px;
    align-items:flex-start;
  }
  .profile-hero-card .profile-hero-actions{
    margin-top:14px;
    padding-top:14px;
    border-top:1px solid #2a2a2a;
  }
}

/* ---- Workshop profile: enterprise mobile (2026-07) ---- */
.profile-hero-actions{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:14px;
}
.profile-hero-actions a.btn,
.profile-hero-actions a.profile-btn-wa,
.profile-hero-actions a.profile-btn-secondary{
  text-decoration:none;
}
.profile-actions-primary{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.profile-actions-primary .profile-btn-book:only-child{
  grid-column:1 / -1;
}
.profile-btn-book{
  background:var(--yellow);
  color:#080808;
  font-weight:900;
  border:0;
  min-height:48px;
  border-radius:12px;
}
.profile-btn-wa{
  background:#128c7e;
  color:#fff;
  font-weight:800;
  border:0;
  min-height:48px;
  border-radius:12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.profile-actions-secondary{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.profile-actions-secondary .profile-btn-secondary:only-child{
  grid-column:1 / -1;
}
.profile-btn-secondary{
  background:#1a1a1a;
  color:#f2f2f2;
  border:1px solid #333;
  font-weight:800;
  min-height:44px;
  border-radius:12px;
}
.profile-actions-muted{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:8px 16px;
  padding-top:2px;
}
.profile-btn-link,
.profile-actions-muted .home-back-link{
  background:transparent;
  border:0;
  color:#9a9a9a;
  font-weight:700;
  font-size:14px;
  min-height:auto;
  padding:6px 2px;
  text-decoration:none;
  cursor:pointer;
}
.profile-btn-link:hover,
.profile-actions-muted .home-back-link:hover{
  color:#fff;
}
.profile-discovery-meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:6px 10px;
  margin:8px 0 10px;
}
.profile-title-row{
  font-size:clamp(1.35rem,5vw,1.85rem);
  line-height:1.15;
}
.profile-city{
  margin:4px 0 0;
  color:#9a9a9a;
  font-size:15px;
}
.profile-verified{
  display:inline-flex;
  margin-top:2px;
}
body.workshop-profile-route .pwa-install-banner,
body.ai-chat-open .pwa-install-banner,
html.claim-landing-route .pwa-install-banner{
  display:none!important;
}
html.claim-landing-route .ai-support-launcher{
  display:none!important;
}
@media(min-width:841px){
  .profile-actions-primary,
  .profile-actions-secondary{
    grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
    max-width:520px;
  }
}
