/* ====== Joe Bones Ink design system ====== */
:root{
  --bg:#070707;
  --bg-2:#0d0c0a;
  --surface:#141210;
  --surface-2:#1b1813;
  --line:#2c271e;
  --line-2:#3a3324;
  --gold:#e6bd4f;
  --gold-2:#c9962f;
  --gold-deep:#a87e23;
  --gold-grad:linear-gradient(135deg,#f0d06a 0%,#d8a93c 50%,#b9831f 100%);
  --ink:#f5f1e8;
  --muted:#9b9486;
  --muted-2:#6f685b;
  --ok:#56c98a;
  --warn:#e0b34a;
  --radius:16px;
  --radius-sm:12px;
  --tab-h:64px;
  --maxw:480px;
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bot:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;height:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  font-size:15px;line-height:1.5;
  overscroll-behavior-y:none;
  -webkit-font-smoothing:antialiased;
}
.brand-font{font-family:'Pirata One','Cinzel',serif;letter-spacing:.5px}
.serif{font-family:'Cinzel',serif}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit}
::-webkit-scrollbar{width:0;height:0}

/* marble backdrop */
.marble{
  background:
    radial-gradient(120% 80% at 15% 0%, rgba(230,189,79,.10), transparent 55%),
    radial-gradient(120% 60% at 90% 10%, rgba(201,150,47,.08), transparent 50%),
    linear-gradient(180deg,#0b0a08,#060605 60%);
  position:relative;
}
.marble::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.22;
  background-image:url("img/marble.svg");background-size:cover;mix-blend-mode:screen;
}

/* app shell */
#app{max-width:var(--maxw);margin:0 auto;min-height:100%;position:relative;background:var(--bg);
  box-shadow:0 0 60px rgba(0,0,0,.6);overflow:hidden}
.screen{display:none;min-height:100vh;min-height:100dvh;flex-direction:column;
  padding-bottom:calc(var(--tab-h) + var(--safe-bot) + 8px)}
.screen.active{display:flex}
.screen.no-tab{padding-bottom:0}

/* top app bar */
.appbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:10px;
  padding:calc(var(--safe-top) + 12px) 16px 12px;background:rgba(7,7,7,.86);
  backdrop-filter:blur(12px);border-bottom:1px solid rgba(44,39,30,.7)}
.appbar h1{font-size:17px;margin:0;font-weight:600;letter-spacing:.3px}
.appbar .center{flex:1;text-align:center}
.iconbtn{width:38px;height:38px;display:grid;place-items:center;border-radius:11px;
  background:var(--surface);border:1px solid var(--line);color:var(--ink)}
.iconbtn svg{width:19px;height:19px}
.appbar .spacer{width:38px}

.scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.pad{padding:18px 16px}

/* buttons */
.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;
  padding:15px 18px;border-radius:13px;font-weight:700;font-size:15px;letter-spacing:.2px}
.btn-gold{background:var(--gold-grad);color:#241a05;box-shadow:0 8px 22px rgba(201,150,47,.28)}
.btn-gold:active{transform:translateY(1px)}
.btn-outline{background:var(--surface);border:1px solid var(--line-2);color:var(--ink)}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.btn-block{margin-top:14px}
.btn svg{width:18px;height:18px}

/* form */
.field{margin:12px 0}
.field label{display:block;font-size:12.5px;color:var(--gold);margin:0 0 7px 2px;
  text-transform:uppercase;letter-spacing:.8px;font-weight:600}
.input,.textarea,select.input{width:100%;padding:14px 14px;background:var(--surface);
  border:1px solid var(--line);border-radius:12px;color:var(--ink);font-size:15px;outline:none}
.input:focus,.textarea:focus{border-color:var(--gold-2);box-shadow:0 0 0 3px rgba(201,150,47,.14)}
.textarea{min-height:104px;resize:vertical}
.input-wrap{position:relative}
.input-wrap .eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--muted)}
.inline-link{color:var(--gold);font-weight:600}
.muted{color:var(--muted)}
.center-text{text-align:center}

/* cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.card+.card{margin-top:14px}
.section-title{font-size:13px;text-transform:uppercase;letter-spacing:1.2px;color:var(--gold);
  font-weight:700;margin:22px 2px 12px}
.section-title:first-child{margin-top:6px}

/* hero / splash */
.hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;
  justify-content:flex-end;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(7,7,7,.25) 0%,rgba(7,7,7,.1) 40%,rgba(7,7,7,.92) 88%,#070707 100%)}
.hero-inner{position:relative;z-index:1;padding:0 24px calc(40px + var(--safe-bot));text-align:center}
.splash-logo{width:84%;max-width:340px;margin:0 auto;filter:drop-shadow(0 6px 20px rgba(0,0,0,.6))}
.login-logo{width:70%;max-width:260px;margin:0 auto;filter:drop-shadow(0 4px 14px rgba(0,0,0,.5))}
.tagline{color:#e7dcc4;letter-spacing:3px;text-transform:uppercase;font-size:12px;margin:16px 0 26px}

/* status row (fake device) */
.statusbar{display:flex;justify-content:space-between;align-items:center;
  padding:calc(var(--safe-top) + 8px) 20px 4px;font-size:13px;font-weight:600;color:var(--ink);
  position:relative;z-index:2}
.statusbar .right{display:flex;gap:6px;align-items:center;opacity:.9}

/* welcome home */
.welcome{display:flex;align-items:center;gap:14px}
.welcome .av{width:54px;height:54px;border-radius:14px;border:1px solid var(--line-2);object-fit:cover}
.welcome small{color:var(--muted);font-size:12.5px}
.welcome h2{margin:2px 0 0;font-size:20px}

/* upcoming appt card */
.appt{display:flex;gap:13px;align-items:center}
.appt img{width:52px;height:52px;border-radius:11px;object-fit:cover;border:1px solid var(--line)}
.appt .meta{flex:1}
.appt .meta b{font-size:14.5px}
.appt .meta span{display:block;color:var(--muted);font-size:12.5px;margin-top:2px}

/* quick actions */
.quick{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:6px}
.quick a{display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px 6px;
  background:var(--surface);border:1px solid var(--line);border-radius:13px;font-size:11.5px;color:var(--muted)}
.quick a .ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;
  background:rgba(230,189,79,.10);color:var(--gold)}
.quick a .ic svg{width:19px;height:19px}

/* horizontal featured strip */
.hstrip{display:flex;gap:10px;overflow-x:auto;padding:2px 0 4px}
.hstrip img{width:92px;height:118px;border-radius:12px;object-fit:cover;flex:0 0 auto;border:1px solid var(--line)}

/* chips / tabs */
.chips{display:flex;gap:9px;overflow-x:auto;padding:4px 0}
.chip{flex:0 0 auto;padding:9px 16px;border-radius:999px;background:var(--surface);
  border:1px solid var(--line);color:var(--muted);font-size:13px;font-weight:600}
.chip.on{background:var(--gold-grad);color:#241a05;border-color:transparent}
.segment{display:flex;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:4px;gap:4px}
.segment button{flex:1;padding:10px;border-radius:9px;font-weight:600;color:var(--muted);font-size:13.5px}
.segment button.on{background:var(--gold-grad);color:#241a05}

/* gallery grid */
.gal{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.gal .cell{position:relative;border-radius:13px;overflow:hidden;aspect-ratio:1/1.18;border:1px solid var(--line)}
.gal .cell img{width:100%;height:100%;object-fit:cover}
.gal .cell:nth-child(3n){aspect-ratio:1/1.4}

/* gallery detail */
.detail-hero{border-radius:18px;overflow:hidden;border:1px solid var(--line);aspect-ratio:1/1.1}
.detail-hero img{width:100%;height:100%;object-fit:cover}
.stat-row{display:flex;gap:18px;color:var(--muted);font-size:13.5px;margin-top:12px;align-items:center}
.stat-row b{color:var(--ink)}

/* artist profile */
.profile-photo{border-radius:18px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/11}
.profile-photo img{width:100%;height:100%;object-fit:cover}
.pstats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:16px 0}
.pstats .s{background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:14px 8px;text-align:center}
.pstats .s b{display:block;color:var(--gold);font-size:20px;font-family:'Cinzel',serif}
.pstats .s span{font-size:11px;color:var(--muted)}

/* list rows (services, settings) */
.rows{display:flex;flex-direction:column;gap:10px}
.row{display:flex;align-items:center;gap:12px;padding:15px 15px;background:var(--surface);
  border:1px solid var(--line);border-radius:13px}
.row.sel{border-color:var(--gold-2);box-shadow:0 0 0 2px rgba(201,150,47,.18)}
.row .label{flex:1}
.row .label b{font-size:14.5px}
.row .label small{display:block;color:var(--muted);font-size:12px}
.row .price{color:var(--gold);font-weight:700;flex:0 0 auto}
.row .chev{width:18px;height:18px;flex:0 0 auto;color:var(--muted-2)}
.row .label b{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:rgba(230,189,79,.10);color:var(--gold)}
.row .ic svg{width:18px;height:18px}
.row .prod{width:42px;height:42px;border-radius:50%;object-fit:cover;border:1px solid var(--line);flex:0 0 auto}

/* date / time pickers */
.dates{display:flex;gap:9px;overflow-x:auto;padding:2px 0}
.date{flex:0 0 auto;width:54px;text-align:center;padding:11px 0;background:var(--surface);
  border:1px solid var(--line);border-radius:13px}
.date small{display:block;color:var(--muted);font-size:11px}
.date b{font-size:17px;font-family:'Cinzel',serif}
.date.on{background:var(--gold-grad);color:#241a05}
.date.on small{color:#3a2c08}
.times{display:flex;gap:9px;flex-wrap:wrap;margin-top:12px}
.time{padding:10px 16px;background:var(--surface);border:1px solid var(--line);border-radius:11px;font-weight:600;font-size:13.5px}
.time.on{background:var(--gold-grad);color:#241a05}

/* confirmation */
.confirm{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 24px;gap:8px}
.confirm .badge{width:96px;height:96px;border-radius:50%;display:grid;place-items:center;
  border:2px solid var(--gold);box-shadow:0 0 40px rgba(230,189,79,.35);margin-bottom:14px}
.confirm .badge svg{width:46px;height:46px;color:var(--gold)}

/* notifications */
.notif{display:flex;gap:12px;padding:13px 0;border-bottom:1px solid var(--line)}
.notif .ic{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:rgba(230,189,79,.10);color:var(--gold);flex:0 0 auto}
.notif .ic svg{width:18px;height:18px}
.notif b{font-size:14px}
.notif p{margin:2px 0 0;color:var(--muted);font-size:12.5px}
.notif time{color:var(--muted-2);font-size:11px;flex:0 0 auto}
.notif.unread{position:relative}
.notif.unread::after{content:"";position:absolute;left:-12px;top:20px;width:6px;height:6px;border-radius:50%;background:var(--gold)}

/* reviews */
.rev-head{text-align:center;padding:8px 0 6px}
.rev-head .big{font-size:46px;font-family:'Cinzel',serif;color:var(--gold);line-height:1}
.stars{color:var(--gold);letter-spacing:2px}
.review{padding:15px 0;border-bottom:1px solid var(--line)}
.review .top{display:flex;justify-content:space-between;align-items:center}
.review .who{display:flex;align-items:center;gap:10px}
.review .who .av{width:38px;height:38px;border-radius:50%;background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--gold);font-weight:700}

/* loyalty */
.loyalty{background:radial-gradient(120% 100% at 50% 0,rgba(230,189,79,.16),transparent 60%),var(--surface);
  border:1px solid var(--line-2);border-radius:18px;padding:22px 18px;text-align:center}
.loyalty .pts{font-size:44px;font-family:'Cinzel',serif;color:var(--gold);line-height:1}
.progress{height:9px;border-radius:9px;background:var(--surface-2);overflow:hidden;margin:14px 0 6px;border:1px solid var(--line)}
.progress i{display:block;height:100%;background:var(--gold-grad);border-radius:9px}

/* shop */
.shop{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.product{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.product .ph{aspect-ratio:1/1;background:var(--bg-2);display:grid;place-items:center;overflow:hidden}
.product .ph img{width:100%;height:100%;object-fit:cover}
.product .info{padding:11px 12px}
.product .info b{font-size:13.5px}
.product .info .price{color:var(--gold);font-weight:700;font-size:13.5px;margin-top:3px}

/* chat */
.chat{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:14px 16px;gap:12px}
.bubble{max-width:78%;padding:11px 14px;border-radius:16px;font-size:14px;line-height:1.4}
.bubble.them{align-self:flex-start;background:var(--surface);border:1px solid var(--line);border-bottom-left-radius:5px}
.bubble.me{align-self:flex-end;background:var(--gold-grad);color:#241a05;border-bottom-right-radius:5px}
.bubble img{border-radius:10px;margin-top:6px;max-width:200px}
.bubble time{display:block;font-size:10px;opacity:.6;margin-top:4px}
.chatbar{display:flex;gap:9px;padding:10px 14px calc(10px + var(--safe-bot));border-top:1px solid var(--line);background:var(--bg)}
.chatbar input{flex:1;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:12px 16px;color:var(--ink);outline:none}
.chatbar .send{width:44px;height:44px;border-radius:50%;background:var(--gold-grad);color:#241a05;display:grid;place-items:center;flex:0 0 auto}

/* aftercare */
.bullets{list-style:none;margin:0;padding:0}
.bullets li{display:flex;gap:11px;padding:9px 0;color:var(--ink);font-size:14px}
.bullets li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold);margin-top:8px;flex:0 0 auto}

/* settings */
.acct{display:flex;align-items:center;gap:13px;padding:4px 0 4px}
.acct .av{width:54px;height:54px;border-radius:50%;border:1px solid var(--line-2);object-fit:cover}
.danger{color:#e06a5a;text-align:center;font-weight:600;width:100%;padding:15px}

/* bottom tab bar */
.tabbar{position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:100%;max-width:var(--maxw);
  display:flex;justify-content:space-around;align-items:center;height:calc(var(--tab-h) + var(--safe-bot));
  padding-bottom:var(--safe-bot);background:rgba(10,9,8,.95);backdrop-filter:blur(14px);
  border-top:1px solid var(--line);z-index:40}
.tabbar.hidden{display:none}
.tab{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--muted-2);font-size:10.5px;font-weight:600;padding:6px 10px}
.tab svg{width:22px;height:22px}
.tab.on{color:var(--gold)}
.tab-badge{position:absolute;top:2px;right:6px;background:var(--gold);color:#000;font-size:10px;font-weight:700;
  min-width:16px;height:16px;padding:0 4px;border-radius:8px;display:flex;align-items:center;justify-content:center;line-height:1}
.admin-only{display:none}
body.is-admin .admin-only{display:flex}
body.is-admin .admin-only.row{display:flex}

/* toast */
.toast{position:fixed;left:50%;bottom:calc(var(--tab-h) + 22px + var(--safe-bot));transform:translateX(-50%) translateY(20px);
  background:var(--surface-2);border:1px solid var(--line-2);color:var(--ink);padding:12px 18px;border-radius:12px;
  font-size:13.5px;font-weight:600;opacity:0;pointer-events:none;transition:.25s;z-index:60;box-shadow:0 10px 30px rgba(0,0,0,.5)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* install banner */
.install{display:none;align-items:center;gap:10px;margin:0 16px 0;padding:12px 14px;background:var(--surface);
  border:1px solid var(--line-2);border-radius:13px}
.install.show{display:flex}
.install img{width:34px;height:34px;border-radius:9px}
.install .t{flex:1;font-size:12.5px}
.install b{font-size:13px}
.install button{padding:9px 14px;border-radius:10px;font-weight:700;font-size:12.5px}
.install .x{color:var(--muted-2);padding:6px}

.divider{display:flex;align-items:center;gap:12px;color:var(--muted-2);font-size:12px;margin:16px 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}
.check{display:flex;gap:10px;align-items:flex-start;margin:14px 2px;font-size:13px;color:var(--muted)}
.check input{margin-top:2px}
.fade-in{animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* form messages */
.form-msg{font-size:13px;margin:2px 2px 12px;min-height:1px}
.form-msg.err{color:var(--warn,#e0796b)}
.form-msg.ok{color:var(--muted)}

/* shop info contact actions */
.contact-actions{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin:4px 0 6px}
.contact-actions .ca{display:flex;flex-direction:column;gap:3px;padding:15px 14px;border:1px solid var(--line);border-radius:14px;background:var(--card,#111);color:var(--ink);text-decoration:none}
.contact-actions .ca .ic{color:var(--gold)}
.contact-actions .ca .ic svg{width:20px;height:20px}
.contact-actions .ca b{font-size:14px}
.contact-actions .ca small{color:var(--muted);font-size:11.5px}

/* admin badge count */
.badge-count{min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--gold);color:#0a0a0a;font-size:11px;font-weight:700;display:none;place-items:center}
.badge-count:not(:empty){display:grid}
