*{box-sizing:border-box;margin:0;padding:0}body{color:#0a0a0a;background:#faf7f2;font-family:DM Sans,sans-serif}.app{max-width:430px;min-height:100vh;margin:0 auto}.splash{text-align:center;background:#0a0a0a;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:40px 24px;display:flex}.splash-logo{color:#f5f0e8;letter-spacing:-1px;font-size:52px;font-weight:900}.splash-logo span{color:#c84b2f}.splash-tagline{color:#8a8580;letter-spacing:3px;margin-top:10px;font-size:12px}.splash-divider{background:#d4a853;width:40px;height:1px;margin:28px auto}.splash-desc{color:#f5f0e899;max-width:280px;font-size:15px;line-height:1.7}.role-cards{flex-wrap:wrap;justify-content:center;gap:16px;margin-top:40px;display:flex}.role-card{cursor:pointer;text-align:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;width:150px;padding:28px 24px;transition:all .25s}.role-card:hover{background:#ffffff1a;border-color:#d4a853;transform:translateY(-3px)}.role-icon{margin-bottom:12px;font-size:32px}.role-label{color:#f5f0e8;font-size:16px;font-weight:700}.role-sub{color:#8a8580;margin-top:4px;font-size:12px}.nav{z-index:100;background:#fff;border-bottom:1px solid #00000014;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.nav-logo{font-size:22px;font-weight:900}.nav-logo span{color:#c84b2f}.back-btn{color:#8a8580;cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:14px}.back-btn:hover{color:#0a0a0a}.page{background:#faf7f2;min-height:100vh}.content{padding:20px 20px 100px}.section-header{margin-bottom:20px}.page-title{color:#0a0a0a;font-size:26px;font-weight:900}.page-sub{color:#8a8580;margin-top:4px;font-size:14px}.search-bar{background:#fff;border:1.5px solid #00000014;border-radius:12px;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;display:flex}.search-bar input{color:#0a0a0a;background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:14px}.search-bar input::placeholder{color:#8a8580}.style-chips{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.chip{cursor:pointer;color:#2c2c2c;background:#fff;border:1.5px solid #00000014;border-radius:20px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:all .2s}.chip.selected{color:#fff;background:#0a0a0a;border-color:#0a0a0a}.artist-card{cursor:pointer;background:#fff;border-radius:18px;margin-bottom:16px;transition:transform .2s,box-shadow .2s;overflow:hidden;box-shadow:0 4px 24px #00000014}.artist-card:hover{transform:translateY(-2px);box-shadow:0 12px 48px #00000024}.artist-card-img{justify-content:center;align-items:center;width:100%;height:200px;display:flex;position:relative}.mock-tattoo{font-size:90px}.style-badge{color:#f5f0e8;text-transform:uppercase;letter-spacing:.5px;background:#0a0a0a;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600;position:absolute;top:12px;left:12px}.avail-badge{color:#fff;background:#22c55e;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600;position:absolute;top:12px;right:12px}.artist-card-body{padding:16px}.artist-name{font-size:19px;font-weight:700}.artist-location{color:#8a8580;margin-top:2px;font-size:13px}.artist-styles{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.artist-style-tag{color:#2c2c2c;background:#f5f0e8;border-radius:5px;padding:3px 10px;font-size:11px;font-weight:500}.artist-meta{justify-content:space-between;align-items:center;margin-top:12px;display:flex}.artist-rate{color:#8a8580;font-size:13px}.artist-rate strong{color:#0a0a0a}.artist-rating{align-items:center;gap:4px;font-size:13px;font-weight:600;display:flex}.review-count{color:#8a8580;font-weight:400}.match-bar{margin-top:12px}.match-label{color:#8a8580;justify-content:space-between;margin-bottom:5px;font-size:12px;display:flex}.match-label strong{color:#c84b2f}.match-track{background:#f5f0e8;border-radius:2px;height:4px;overflow:hidden}.match-fill{background:linear-gradient(90deg,#c84b2f,#d4a853);border-radius:2px;height:100%;transition:width .6s}.tab-bar{z-index:100;background:#fff;border-top:1px solid #00000014;width:100%;max-width:430px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.tab-item{cursor:pointer;color:#8a8580;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:10px 0 8px;font-family:inherit;transition:color .2s;display:flex}.tab-item.active{color:#c84b2f}.tab-icon{font-size:20px}.tab-label{font-size:10px;font-weight:500}.empty-state{text-align:center;color:#8a8580;padding:48px 24px}.empty-icon{margin-bottom:12px;font-size:48px}.empty-state p{font-size:14px;line-height:1.6}.profile-hero{text-align:center;background:#0a0a0a;padding:32px 20px 24px}.profile-avatar{background:#f5f0e8;border:3px solid #d4a853;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 12px;font-size:36px;display:flex}.profile-name{color:#f5f0e8;font-size:24px;font-weight:900}.profile-loc{color:#8a8580;margin-top:4px;font-size:13px}.profile-stats{background:#ffffff0d;border-radius:12px;margin-top:20px;display:flex;overflow:hidden}.profile-stat{text-align:center;border-right:1px solid #ffffff14;flex:1;padding:14px 8px}.profile-stat:last-child{border-right:none}.profile-stat-val{color:#f5f0e8;font-size:20px;font-weight:700}.profile-stat-lbl{color:#8a8580;margin-top:2px;font-size:11px}.tag-pill{color:#c84b2f;background:#c84b2f1a;border-radius:20px;margin:3px 3px 3px 0;padding:4px 12px;font-size:12px;font-weight:600;display:inline-block}.info-card{background:#fff;border-radius:14px;margin-bottom:16px;padding:16px;box-shadow:0 4px 24px #00000014}.info-card-title{margin-bottom:8px;font-size:15px;font-weight:700}.info-card-text{color:#2c2c2c;font-size:14px;line-height:1.7}.portfolio-grid{border-radius:14px;grid-template-columns:repeat(3,1fr);gap:3px;margin-bottom:16px;display:grid;overflow:hidden}.portfolio-item{aspect-ratio:1;cursor:pointer;justify-content:center;align-items:center;font-size:40px;transition:opacity .2s;display:flex}.portfolio-item:hover{opacity:.8}.booking-row{border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;padding:10px 0;font-size:14px;display:flex}.booking-row:last-child{border-bottom:none}.booking-row-label{color:#8a8580}.booking-row-val{font-weight:600}.btn-row{gap:10px;margin-top:8px;padding-bottom:20px;display:flex}.btn{cursor:pointer;text-align:center;border:none;border-radius:12px;flex:1;padding:15px;font-family:inherit;font-size:15px;font-weight:600;transition:all .2s}.btn-primary{color:#fff;background:#c84b2f}.btn-primary:hover{background:#b03d25;transform:translateY(-1px)}.btn-secondary{color:#0a0a0a;background:#fff;border:1.5px solid #00000014}.btn-secondary:hover{border-color:#0a0a0a}.form-group{margin-bottom:18px}.form-label{color:#8a8580;letter-spacing:1px;margin-bottom:8px;font-size:12px;font-weight:700;display:block}.form-select{color:#0a0a0a;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238a8580' d='M6 8L1 3h10z'/%3E%3C/svg%3E") right 14px center no-repeat;border:1.5px solid #00000014;border-radius:10px;outline:none;width:100%;padding:13px 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.form-select:focus{border-color:#c84b2f}.form-textarea{color:#0a0a0a;resize:vertical;background:#fff;border:1.5px solid #00000014;border-radius:10px;outline:none;width:100%;min-height:100px;padding:13px 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.form-textarea:focus{border-color:#c84b2f}.date-grid{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:20px;display:grid}.date-chip{text-align:center;cursor:pointer;background:#fff;border:1.5px solid #00000014;border-radius:12px;padding:12px 4px;transition:all .2s}.date-chip:hover{border-color:#0a0a0a}.date-chip.selected{background:#0a0a0a;border-color:#0a0a0a}.date-day{color:#8a8580;font-size:11px;font-weight:500}.date-chip.selected .date-day{color:#fff9}.date-num{color:#0a0a0a;margin-top:2px;font-size:20px;font-weight:700}.date-chip.selected .date-num{color:#fff}.time-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px;display:grid}.time-chip{text-align:center;cursor:pointer;background:#fff;border:1.5px solid #00000014;border-radius:10px;padding:11px 4px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s}.time-chip:hover{border-color:#c84b2f}.time-chip.selected{color:#fff;background:#c84b2f;border-color:#c84b2f}.booking-note{text-align:center;color:#8a8580;margin-top:10px;padding-bottom:40px;font-size:12px}.confirm-hero{text-align:center;background:#fff;border-bottom:1px solid #0000000f;padding:40px 24px 24px}.confirm-icon{margin-bottom:16px;font-size:64px}.confirm-title{color:#0a0a0a;font-size:28px;font-weight:900}.confirm-sub{color:#8a8580;max-width:300px;margin-top:8px;margin-left:auto;margin-right:auto;font-size:14px;line-height:1.6}.next-step{border-bottom:1px solid #0000000f;align-items:flex-start;gap:12px;padding:10px 0;display:flex}.next-step:last-child{border-bottom:none}.next-step-icon{flex-shrink:0;margin-top:2px;font-size:20px}.next-step-text strong{margin-bottom:2px;font-size:14px;font-weight:700;display:block}.next-step-text p{color:#8a8580;font-size:13px;line-height:1.5}.convo-list{flex-direction:column;display:flex}.convo-item{cursor:pointer;border-bottom:1px solid #0000000f;align-items:center;gap:14px;padding:14px 0;transition:all .15s;display:flex}.convo-item:hover{background:#f5f0e8;border-radius:12px;margin:0 -20px;padding:14px 20px}.convo-avatar{background:#f5f0e8;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:24px;display:flex;position:relative}.convo-dot{background:#c84b2f;border:2px solid #fff;border-radius:50%;width:12px;height:12px;position:absolute;top:2px;right:2px}.convo-info{flex:1;min-width:0}.convo-name{color:#0a0a0a;font-size:15px;font-weight:600}.convo-preview{color:#8a8580;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:13px;overflow:hidden}.convo-time{color:#8a8580;flex-shrink:0;font-size:11px}.chat-wrap{background:#faf7f2;flex-direction:column;height:100vh;display:flex}.chat-header{background:#fff;border-bottom:1px solid #00000014;flex-shrink:0;align-items:center;gap:12px;padding:14px 16px;display:flex}.chat-avatar{background:#f5f0e8;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.chat-info{flex:1}.chat-name{font-size:15px;font-weight:600}.chat-status{color:#22c55e;font-size:12px}.chat-profile-btn{cursor:pointer;color:#0a0a0a;background:0 0;border:1.5px solid #00000014;border-radius:8px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .2s}.chat-profile-btn:hover{border-color:#0a0a0a}.chat-messages{flex-direction:column;flex:1;gap:10px;padding:16px;display:flex;overflow-y:auto}.msg{flex-direction:column;max-width:75%;display:flex}.msg.them .msg-bubble{color:#0a0a0a;background:#fff;border-radius:4px 16px 16px;box-shadow:0 2px 8px #0000000f}.msg.me{align-self:flex-end}.msg.me .msg-bubble{color:#f5f0e8;background:#0a0a0a;border-radius:16px 4px 16px 16px}.msg-bubble{padding:11px 14px;font-size:14px;line-height:1.5}.msg-time{color:#8a8580;margin-top:4px;padding:0 4px;font-size:11px}.msg.me .msg-time{text-align:right}.chat-input-bar{background:#fff;border-top:1px solid #00000014;flex-shrink:0;align-items:center;gap:10px;padding:12px 16px;display:flex}.chat-attach-btn{cursor:pointer;background:0 0;border:none;padding:4px;font-size:20px}.chat-input{border:1.5px solid #00000014;border-radius:24px;outline:none;flex:1;padding:11px 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.chat-input:focus{border-color:#c84b2f}.chat-send-btn{color:#fff;cursor:pointer;background:#c84b2f;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;transition:background .2s;display:flex}.chat-send-btn:hover{background:#b03d25}.dash-header{background:#0a0a0a;padding:32px 20px 28px}.dash-greeting{color:#8a8580;letter-spacing:1px;text-transform:uppercase;font-size:13px}.dash-name{color:#f5f0e8;margin-top:4px;font-size:26px;font-weight:900}.dash-stats{grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px;display:grid}.dash-stat{text-align:center;background:#ffffff14;border-radius:12px;padding:14px 10px}.dash-stat-val{color:#f5f0e8;font-size:22px;font-weight:900}.dash-stat-lbl{color:#8a8580;margin-top:2px;font-size:11px}.request-card{background:#fff;border-radius:16px;margin-bottom:12px;padding:16px;box-shadow:0 4px 24px #00000014}.request-top{align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.request-avatar{background:#f5f0e8;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.request-info{flex:1}.request-name{font-size:15px;font-weight:700}.request-style{color:#8a8580;margin-top:2px;font-size:12px}.request-time{color:#8a8580;flex-shrink:0;font-size:11px}.request-desc{color:#2c2c2c;margin-bottom:12px;font-size:13px;line-height:1.6}.request-actions{gap:8px;display:flex}.req-btn{cursor:pointer;border:none;border-radius:8px;flex:1;padding:10px;font-family:inherit;font-size:13px;font-weight:700;transition:all .2s}.req-btn-accept{color:#fff;background:#0a0a0a}.req-btn-accept:hover{background:#2c2c2c}.req-btn-decline{color:#2c2c2c;background:#f5f0e8}.req-btn-decline:hover{background:#e8e0d0}.request-status{text-align:center;border-radius:8px;padding:10px;font-size:13px;font-weight:700}.request-status.accepted{color:#16a34a;background:#22c55e1a}.request-status.declined{color:#8a8580;background:#0000000d}.tag-pill-add{color:#8a8580;cursor:pointer;border:1.5px dashed #00000026;border-radius:20px;margin:3px 3px 3px 0;padding:4px 12px;font-size:12px;font-weight:600;transition:all .2s;display:inline-block}.tag-pill-add:hover{color:#c84b2f;border-color:#c84b2f}.btn-saved{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:12px;font-family:inherit;transition:all .2s}.auth-page{background:#0a0a0a;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:40px 20px;display:flex}.auth-logo{color:#f5f0e8;letter-spacing:-1px;margin-bottom:6px;font-size:36px;font-weight:900}.auth-logo span{color:#c84b2f}.auth-tagline{color:#8a8580;letter-spacing:3px;margin-bottom:32px;font-size:11px}.auth-card{background:#fff;border-radius:24px;width:100%;max-width:390px;padding:28px 24px}.auth-title{color:#0a0a0a;font-size:24px;font-weight:900}.auth-sub{color:#8a8580;margin-top:4px;margin-bottom:20px;font-size:14px}.role-toggle{background:#f5f0e8;border-radius:10px;gap:4px;margin-bottom:20px;padding:4px;display:flex}.role-toggle-btn{cursor:pointer;color:#8a8580;background:0 0;border:none;border-radius:7px;flex:1;padding:8px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.role-toggle-btn.active{color:#0a0a0a;background:#fff;box-shadow:0 1px 4px #0000001a}.form-input{color:#0a0a0a;background:#fff;border:1.5px solid #00000014;border-radius:10px;outline:none;width:100%;padding:13px 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.form-input:focus{border-color:#c84b2f}.auth-forgot{text-align:right;color:#c84b2f;cursor:pointer;margin-top:-10px;margin-bottom:20px;font-size:13px;font-weight:500}.btn-google{cursor:pointer;color:#0a0a0a;background:#fff;border:1.5px solid #00000014;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:flex}.btn-google:hover{border-color:#0a0a0a}.auth-divider{color:#8a8580;align-items:center;gap:12px;margin:16px 0;font-size:13px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:#00000014;flex:1;height:1px}.auth-switch{text-align:center;color:#8a8580;margin-top:20px;font-size:14px}.auth-switch span{color:#c84b2f;cursor:pointer;font-weight:600}.auth-terms{color:#8a8580;text-align:center;margin-bottom:16px;font-size:12px;line-height:1.5}.auth-terms span{color:#c84b2f;cursor:pointer}.auth-error{color:#c84b2f;text-align:center;background:#c84b2f1a;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;font-weight:500}.step-indicator{gap:8px;margin-bottom:24px;display:flex}.step-dot{background:#00000014;border-radius:2px;flex:1;height:4px;transition:all .3s}.step-dot.active{background:#c84b2f}
