/* ============================================================================
   Magic Hand Massage — styles. Two skins share one file:
     body.admin  -> dark, TradingView-style back office (mirrors PartsPulse)
     body.public -> warm, light spa marketing site + booking flow
   ============================================================================ */
:root{
  --bg:#131722; --panel:#1e222d; --panel2:#181b26; --line:#2a2e39;
  --txt:#d1d4dc; --mut:#8b97a8; --acc:#2962ff;
  --up:#26a69a; --down:#ef5350; --amber:#f1c40f;
  /* spa palette */
  --spa-bg:#f6f1ea; --spa-card:#fffdfb; --spa-ink:#3a3230; --spa-mut:#8a7f78;
  --spa-acc:#7c9a76; --spa-acc2:#caa46a; --spa-line:#e7ddd1;
}
*{box-sizing:border-box;}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,system-ui,sans-serif;font-size:14px;}

/* ===================== BACK OFFICE (dark) ===================== */
body.admin{background:var(--bg);color:var(--txt);}
body.admin a{color:var(--acc);text-decoration:none;}

.topbar{display:flex;align-items:center;gap:18px;padding:0 18px;height:52px;
  background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10;flex-wrap:wrap;}
.brand{font-weight:700;font-size:15px;white-space:nowrap;}
.brand span{color:var(--txt);}
.tabs{display:flex;gap:2px;flex:1;overflow-x:auto;}
.tab{padding:8px 14px;border-radius:6px;color:var(--mut);font-weight:600;white-space:nowrap;}
.tab:hover{background:var(--panel2);color:var(--txt);}
.tab.active{background:var(--acc);color:#fff;}
.userbox{display:flex;align-items:center;gap:12px;font-size:12px;white-space:nowrap;}
.userbox .who{color:var(--txt);font-weight:600;}
.userbox .logout,.userbox .viewsite{color:var(--mut);}
.env{font-size:11px;color:var(--mut);letter-spacing:.5px;white-space:nowrap;}

.content{padding:18px;max-width:1180px;margin:0 auto;}
body.admin h1{font-size:20px;margin:0 0 14px;}
body.admin h2{font-size:13px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px;font-weight:600;}

.card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px;margin-bottom:16px;}
.muted{color:var(--mut);}
.backlink{color:var(--mut);font-weight:600;font-size:13px;display:inline-block;margin-bottom:8px;}

/* tables */
body.admin table{width:100%;border-collapse:collapse;}
body.admin th,body.admin td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line);}
body.admin th{color:var(--mut);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px;}
body.admin tbody tr:hover{background:var(--panel2);}
.strat{font-weight:600;color:var(--txt);}
.clickrows tbody tr{cursor:pointer;}
.frpill{font-size:10px;padding:1px 6px;border-radius:4px;background:#26303f;color:var(--mut);margin-left:6px;}
.dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:7px;vertical-align:middle;}

/* tags + notices */
.tag{font-size:11px;padding:2px 8px;border-radius:5px;font-weight:600;}
.tag.buy{background:#10342a;color:var(--up);}
.tag.neutral{background:#26303f;color:var(--mut);}
.empty{color:var(--mut);padding:34px 10px;text-align:center;font-size:13px;}
.notice{padding:10px 12px;border-radius:8px;font-size:13px;margin-bottom:14px;}
.notice.ok{background:#10342a;border:1px solid #1c5b48;color:var(--up);}
.notice.warn{background:#3a1d1d;border:1px solid #5a2a2a;color:#ffb4b4;}

/* forms (dark) */
.stack{display:flex;flex-direction:column;gap:12px;max-width:460px;}
.formgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px 16px;align-items:end;}
.formgrid.sub{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:14px;margin-top:10px;}
.formgrid .grow{grid-column:1/-1;}
.formgrid hr.full,.formgrid .full{grid-column:1/-1;border:none;border-top:1px solid var(--line);}
.formactions{grid-column:1/-1;display:flex;gap:10px;}
label{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--mut);
  text-transform:uppercase;letter-spacing:.4px;}
label.check{flex-direction:row;align-items:center;gap:8px;text-transform:none;letter-spacing:0;font-size:13px;color:var(--txt);}
label.check.big{grid-column:1/-1;}
input,select,textarea{background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  border-radius:6px;padding:8px 9px;font-size:13px;font-family:inherit;}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--acc);}
input[type=checkbox]{width:16px;height:16px;}
button,.btn{background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:6px;
  padding:8px 16px;font-weight:600;font-size:13px;cursor:pointer;text-decoration:none;display:inline-block;}
button:hover,.btn:hover{border-color:var(--acc);}
button.primary,.btn.primary{background:var(--acc);color:#fff;border-color:var(--acc);}
button.primary:hover{filter:brightness(1.1);}
button.danger,.btn.danger{color:#ffb4b4;border-color:#5a2a2a;}
fieldset{border:1px solid var(--line);border-radius:8px;padding:12px;grid-column:1/-1;}
legend{color:var(--mut);font-size:12px;text-transform:uppercase;letter-spacing:.4px;padding:0 6px;}
.clientpick .newclient{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-top:8px;}
.svcassign{display:flex;flex-wrap:wrap;gap:6px 18px;}
.svcassign label.check{min-width:140px;}
.areagrid{grid-column:1/-1;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:4px 16px;
  background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:10px 12px;}
.visitlist{display:flex;flex-direction:column;gap:10px;}
.visititem{border:1px solid var(--line);border-radius:8px;padding:10px 12px;background:var(--panel2);}
.visithd{display:flex;align-items:center;gap:10px;}
.visithd .editlink{margin-left:auto;}
.visitmeta{color:var(--mut);font-size:13px;margin-top:3px;}
.visitline{font-size:13px;margin-top:5px;}
.visitline span{color:var(--mut);}
.visitline.notebody{white-space:pre-wrap;background:var(--bg);border-radius:6px;padding:7px 9px;margin-top:6px;}
.statusrow{display:flex;gap:10px;flex-wrap:wrap;}
.statusrow form{margin:0;}
.editlink{color:var(--acc);cursor:pointer;font-size:12px;font-weight:600;}
.addnew{margin-top:12px;}
.hourstbl{max-width:520px;}
.hourstbl input[type=time]{width:130px;}

/* login */
.loginwrap{display:flex;justify-content:center;padding-top:40px;}
.logincard{width:340px;}

/* calendar */
.calbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:8px;}
.calbar h1{margin:0;}
.calbar-right{display:flex;gap:10px;align-items:center;}
#calendar{--fc-border-color:var(--line);--fc-page-bg-color:var(--panel);background:var(--panel);
  color:var(--txt);border-radius:8px;padding:6px;}
.fc .fc-toolbar-title{font-size:16px;}
.fc .fc-button{background:var(--panel2);border-color:var(--line);color:var(--txt);text-transform:capitalize;}
.fc .fc-button-primary:not(:disabled).fc-button-active{background:var(--acc);border-color:var(--acc);}
.fc-theme-standard td,.fc-theme-standard th{border-color:var(--line);}
.fc .fc-timegrid-slot{height:1.6em;}
.fc-event{cursor:pointer;font-size:11px;}

/* two-column detail */
.sc-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media (max-width:760px){.sc-cols{grid-template-columns:1fr;}}

.searchbar{display:flex;gap:8px;align-items:center;margin:4px 0 14px;}
.searchbar input[type=search]{flex:1;max-width:420px;}
.clearlink{font-size:12px;color:var(--mut);}

/* ===================== PUBLIC SITE (warm) ===================== */
body.public{background:var(--spa-bg);color:var(--spa-ink);}
body.public a{color:var(--spa-acc);text-decoration:none;}

.site-top{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding:14px 26px;background:var(--spa-card);border-bottom:1px solid var(--spa-line);position:sticky;top:0;z-index:10;}
.site-brand{font-weight:700;font-size:18px;color:var(--spa-ink);}
.site-nav{display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.site-nav a{color:var(--spa-ink);font-weight:600;}
.site-nav a:hover{color:var(--spa-acc);}
.book-btn{background:var(--spa-acc);color:#fff !important;border-radius:24px;padding:9px 20px;font-weight:700;
  display:inline-block;border:none;cursor:pointer;}
.book-btn:hover{filter:brightness(1.06);}
.book-btn.big{padding:14px 34px;font-size:16px;}
.book-btn.small{padding:6px 14px;font-size:13px;}

.site-flash{max-width:900px;margin:14px auto;padding:11px 16px;border-radius:10px;}
.site-flash.error{background:#fbe6e3;color:#9a3026;border:1px solid #efb9b1;}
.site-flash.ok{background:#e6efe2;color:#3f6a36;border:1px solid #bcd6b2;}

.hero{background:linear-gradient(135deg,#e9e1d4,#dfe7d8);padding:80px 22px;text-align:center;}
.hero-inner{max-width:720px;margin:0 auto;}
.hero h1{font-size:44px;margin:0 0 12px;color:var(--spa-ink);}
.lead{font-size:19px;color:var(--spa-mut);margin:0 0 26px;}
.hero-sub{margin-top:18px;color:var(--spa-mut);font-size:14px;}

.section{max-width:1040px;margin:0 auto;padding:56px 22px;}
.section.alt{background:var(--spa-card);max-width:none;}
.section.alt > *{max-width:1040px;margin-left:auto;margin-right:auto;}
.section.cta{text-align:center;}
.section.cta h2{font-size:28px;margin-bottom:22px;}
.sec-title{font-size:30px;text-align:center;margin:0 0 30px;color:var(--spa-ink);}
.cat-title{font-size:20px;color:var(--spa-acc);margin:28px 0 12px;}
.center{text-align:center;margin-top:18px;}
.textlink{color:var(--spa-acc);font-weight:700;}

.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;}
.svc-card{background:var(--spa-card);border:1px solid var(--spa-line);border-radius:14px;padding:20px;
  display:flex;flex-direction:column;gap:8px;}
.svc-card.pick{transition:transform .08s, box-shadow .08s;}
.svc-card.pick:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08);}
.svc-name{font-size:18px;font-weight:700;color:var(--spa-ink);}
.svc-meta{color:var(--spa-mut);}
.svc-meta strong{color:var(--spa-acc2);}
.svc-desc{color:var(--spa-mut);font-size:13px;margin:4px 0 0;}

.price-list{display:flex;flex-direction:column;gap:2px;}
.price-row{display:flex;align-items:center;gap:16px;padding:14px 6px;border-bottom:1px solid var(--spa-line);}
.pr-main{flex:1;}
.pr-name{font-weight:700;color:var(--spa-ink);}
.pr-desc{color:var(--spa-mut);font-size:13px;}
.pr-dur{color:var(--spa-mut);width:80px;text-align:right;}
.pr-price{font-weight:700;color:var(--spa-acc2);width:80px;text-align:right;}

.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px;}
.review-card{background:var(--spa-bg);border:1px solid var(--spa-line);border-radius:14px;padding:20px;}
.stars{color:var(--spa-acc2);font-size:18px;letter-spacing:2px;}
.review-card p{font-style:italic;color:var(--spa-ink);}
.review-name{color:var(--spa-mut);font-weight:600;}

.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin:24px 0;}
.gallery-tile{background:var(--spa-card);border:1px solid var(--spa-line);border-radius:14px;
  height:160px;display:flex;align-items:center;justify-content:center;font-size:48px;}

.contact-cols{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
@media (max-width:740px){.contact-cols{grid-template-columns:1fr;}}
.card-soft{background:var(--spa-card);border:1px solid var(--spa-line);border-radius:14px;padding:24px;}
.card-soft h2{margin-top:0;color:var(--spa-ink);}
.card-soft p{color:var(--spa-ink);}

.site-foot{background:#2c2926;color:#d8cfc6;padding:36px 26px 20px;margin-top:40px;}
.foot-cols{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;max-width:1040px;margin:0 auto;}
.site-foot a{color:#e7d9bf;}
.foot-brand{font-weight:700;font-size:17px;margin-bottom:6px;}
.foot-fine{text-align:center;color:#9a9088;margin-top:24px;font-size:12px;}

/* ===================== BOOKING FLOW ===================== */
.book.narrow{max-width:560px;}
.book-steps{display:flex;gap:10px;justify-content:center;margin-bottom:18px;font-size:13px;}
.book-steps span{color:var(--spa-mut);padding:4px 12px;border-radius:20px;background:var(--spa-card);border:1px solid var(--spa-line);}
.book-steps span.on{background:var(--spa-acc);color:#fff;border-color:var(--spa-acc);}
.book-steps span.done{color:var(--spa-acc);border-color:var(--spa-acc);}
.back{display:inline-block;margin-bottom:12px;}
.slotfilters{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;margin-bottom:22px;}
body.public label{color:var(--spa-mut);}
body.public input,body.public select,body.public textarea{background:#fff;border:1px solid var(--spa-line);color:var(--spa-ink);}
body.public input:focus,body.public select:focus{border-color:var(--spa-acc);}
.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px;}
.slot{background:var(--spa-card);border:1px solid var(--spa-acc);color:var(--spa-acc) !important;
  border-radius:10px;padding:12px 0;text-align:center;font-weight:700;}
.slot:hover{background:var(--spa-acc);color:#fff !important;}
.book-summary{background:var(--spa-card);border:1px solid var(--spa-line);border-radius:12px;
  padding:18px;margin:18px 0;display:flex;flex-direction:column;gap:8px;}
.book-summary div{display:flex;justify-content:space-between;gap:12px;color:var(--spa-ink);}
.book-summary span{color:var(--spa-mut);}
.deposit-note{background:#fbf2dd;border:1px solid #e7cf9a;color:#7a5d22;border-radius:10px;padding:12px 14px;margin-bottom:14px;font-size:13px;}
.hint{color:var(--spa-mut);font-size:12px;margin:-4px 0 4px;}
body.public .stack{max-width:none;}
body.public .stack button{align-self:flex-start;}
.reasonbox{border:1px solid var(--spa-line);border-radius:12px;padding:14px 16px;margin-bottom:6px;}
.reasonbox legend{color:var(--spa-ink);font-weight:700;padding:0 6px;}
.reasonbox .radio{display:inline-flex;align-items:center;gap:7px;margin-right:18px;color:var(--spa-ink);font-weight:600;}
.reasonbox .reasonnote{display:block;width:100%;margin-top:10px;}
.big-check{width:64px;height:64px;border-radius:50%;background:var(--spa-acc);color:#fff;font-size:34px;
  display:flex;align-items:center;justify-content:center;margin:0 auto 10px;}
.empty{color:var(--spa-mut);}
body.public .empty{padding:30px;text-align:center;}

@media (max-width:820px){
  .topbar{height:auto;padding:8px 12px;}
  .topbar .tabs{order:4;flex-basis:100%;}      /* tabs drop to their own full row */
  .userbox{margin-left:auto;}
}
@media (max-width:640px){
  .hero h1{font-size:32px;}
  .content{padding:12px;}
  .sec-title{font-size:24px;}
}
