/* SessionKit — app shell + shared layout */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;height:100%;}
body{
  font-family:var(--font);
  -webkit-font-smoothing:antialiased;
  background:radial-gradient(130% 90% at 50% 0%, #EFEADD 0%, #E3DECF 72%);
  color:var(--text);
}
button{font-family:inherit;}
a{color:inherit;text-decoration:none;}
.sk-scroll::-webkit-scrollbar{width:0;height:0;}
.sk-scroll{scrollbar-width:none;}
@keyframes scpulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.6);opacity:.4;}}
@keyframes skfade{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}

/* ---- App frame ---- */
#app{display:flex;min-height:100vh;width:100%;}

/* Sidebar (desktop) */
.sk-sidebar{display:none;}
@media (min-width:980px){
  .sk-sidebar{
    display:flex;flex-direction:column;width:248px;flex-shrink:0;
    background:var(--surface);border-right:1px solid var(--input);
    padding:26px 20px;position:sticky;top:0;height:100vh;
  }
}
.sk-brandblock{margin-bottom:26px;}
.sk-prac-name{font-size:1.08rem;font-weight:800;color:var(--heading);letter-spacing:-0.2px;}
.sk-prac-studio{font-size:0.8rem;color:var(--muted);margin-top:2px;}
.sk-byline{display:flex;align-items:center;gap:8px;margin-top:14px;}
.sk-logo{width:26px;height:26px;border-radius:8px;background:var(--green);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.sk-logo span{width:9px;height:9px;border-radius:50%;background:var(--gold);}
.sk-byline small{font-size:0.72rem;color:var(--muted);font-weight:700;letter-spacing:0.2px;}
.sk-nav{display:flex;flex-direction:column;gap:3px;margin-top:8px;}
.sk-nav a{
  display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:11px;
  font-size:0.92rem;font-weight:600;color:var(--text-2);cursor:pointer;
}
.sk-nav a:hover{background:var(--fill-1);}
.sk-nav a.active{background:var(--green);color:#fff;}
.sk-nav a.active svg{stroke:#fff;}
.sk-nav a svg{stroke:currentColor;flex-shrink:0;}
.sk-nav .sk-nav-add{color:var(--green);font-weight:800;}
.sk-sidebar-foot{margin-top:auto;font-size:0.7rem;color:var(--faint);}

/* Content column */
#view{flex:1;min-width:0;display:flex;flex-direction:column;}
.sk-page{flex:1;animation:skfade .22s ease;}
/* Mobile-first column: content centers, comfortable width */
.sk-mobile{max-width:460px;margin:0 auto;padding:18px 18px 96px;width:100%;}
@media (min-width:980px){
  .sk-mobile{max-width:560px;padding:34px 28px 40px;}
}
/* Desktop-wide layouts span the content area */
.sk-wide{max-width:1180px;margin:0 auto;padding:32px 30px 60px;width:100%;}

/* Tablet tier (e.g. iPad portrait, 600–979px): keep the bottom tab bar but widen
   the content column so it doesn't sit as a thin strip on a large screen. */
@media (min-width:600px) and (max-width:979px){
  .sk-mobile,.sk-clients,.sk-add,.sk-ns,.sk-plan,.sk-profile,.sk-settings,
  .sk-log,.sk-booking,.sk-dash,.sk-biz,.sk-cal,.sk-cd{
    max-width:700px;padding-left:30px;padding-right:30px;
  }
}

/* Bottom tab bar (mobile) */
.sk-tabbar{
  position:fixed;bottom:0;left:0;right:0;z-index:40;
  display:flex;align-items:flex-start;justify-content:space-around;
  background:#fff;border-top:1px solid #E9E1CF;padding:9px 10px max(14px,env(safe-area-inset-bottom));
}
@media (min-width:980px){ .sk-tabbar{display:none;} }
.sk-tab{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;color:var(--faint);cursor:pointer;}
.sk-tab.active{color:var(--green);}
.sk-tab span{font-size:0.56rem;font-weight:600;letter-spacing:0.2px;}
.sk-tab.active span{font-weight:700;}
.sk-tab-add .sk-fab{
  width:50px;height:50px;border-radius:50%;background:var(--green);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 16px rgba(28,63,44,0.32);margin-top:-13px;
}

/* Shared primitives reused across views */
.sk-pill{display:inline-flex;align-items:center;font-weight:800;border-radius:var(--r-pill);white-space:nowrap;}
.sk-btn{font-family:inherit;cursor:pointer;border-radius:var(--r-pill);font-weight:700;border:1.5px solid var(--border);background:#fff;color:var(--green);}
.sk-btn:hover{background:var(--fill-1);}
.sk-btn-primary{background:var(--green);color:#fff;border:none;box-shadow:var(--sh-cta);}
.sk-btn-primary:hover{background:var(--green-hover);}
.sk-card{background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-card);}
.sk-avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;}
.sk-eyebrow{font-size:0.6rem;font-weight:800;letter-spacing:0.5px;text-transform:uppercase;color:var(--faint);}

/* Modal backdrop */
.sk-backdrop{position:fixed;inset:0;background:rgba(20,45,30,0.42);z-index:60;display:flex;align-items:center;justify-content:center;padding:18px;animation:skfade .18s ease;}
.sk-sheet{position:fixed;left:0;right:0;bottom:0;z-index:61;background:#fff;border-radius:22px 22px 0 0;box-shadow:var(--sh-modal);animation:skfade .2s ease;max-height:88vh;overflow-y:auto;}
.sk-modal-card{background:#fff;border-radius:20px;box-shadow:var(--sh-modal);max-width:440px;width:100%;max-height:88vh;overflow-y:auto;}

.sk-toast{position:fixed;left:50%;bottom:90px;transform:translateX(-50%);z-index:80;background:var(--green);color:#fff;font-weight:700;font-size:0.86rem;padding:11px 18px;border-radius:var(--r-pill);box-shadow:0 8px 24px rgba(28,63,44,0.3);animation:skfade .2s ease;}
@media (min-width:980px){ .sk-toast{bottom:30px;} }
