
/* ONBOARDING-r34 — visual polish for role cabinets after first-entry onboarding.
   Scope: visual-only guards for client/master/STO cabinets. No API/DB/onboarding routing changes. */

:root{
  --cab-r34-bg:#f7f7f8;
  --cab-r34-card:#ffffff;
  --cab-r34-line:rgba(15,23,42,.08);
  --cab-r34-shadow:0 18px 46px rgba(15,23,42,.08);
  --cab-r34-soft-shadow:0 10px 28px rgba(15,23,42,.06);
  --cab-r34-orange:#ff6a00;
}

/* Client cabinet */
.cab-hero{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg,#fff 0%,#f7f7f8 100%);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.cab-hero::before{
  content:'';
  position:absolute;
  inset:-120px -80px auto auto;
  width:360px;
  height:360px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,106,0,.18),rgba(255,106,0,0) 68%);
  pointer-events:none;
}
.cab-hero .container{
  position:relative;
  z-index:1;
}
.cab-profile-row{
  border:1px solid var(--cab-r34-line);
  border-radius:26px;
  background:rgba(255,255,255,.82);
  box-shadow:var(--cab-r34-shadow);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  padding:clamp(16px,2.4vw,26px);
}
.cab-avatar-wrap{
  filter:drop-shadow(0 12px 18px rgba(255,106,0,.13));
}
.cab-avatar,
.cab-avatar--photo{
  border:3px solid rgba(255,255,255,.9);
  box-shadow:0 12px 26px rgba(15,23,42,.12);
}
.cab-name{
  letter-spacing:-.045em;
}
.cab-profile-meta{
  gap:8px;
}
.cab-phone-chip,
.cab-car-chip,
.rbadge{
  min-height:30px;
  border-radius:999px!important;
  border:1px solid rgba(15,23,42,.08);
  background:rgba(255,255,255,.78);
  box-shadow:0 5px 14px rgba(15,23,42,.04);
}
.cab-mini-stats{
  margin-top:16px;
  gap:12px;
}
.cab-ms-item{
  border-radius:20px;
  border:1px solid var(--cab-r34-line);
  background:rgba(255,255,255,.86);
  box-shadow:var(--cab-r34-soft-shadow);
}
.cab-pane>.container{
  max-width:min(100% - 28px,1120px);
}
.profile-form-card,
.cst-card,
.loy-hero,
.loy-lvl-card,
.diag-account-card,
.hist-item,
.notif-item{
  border:1px solid var(--cab-r34-line)!important;
  border-radius:22px!important;
  background:var(--cab-r34-card)!important;
  box-shadow:var(--cab-r34-soft-shadow)!important;
}
.profile-form-card{
  padding:clamp(18px,2.4vw,28px)!important;
}
.pfc-title,
.cst-section-title{
  letter-spacing:-.035em;
}
.pf-input{
  min-height:48px;
  border-radius:16px!important;
  background:#fff!important;
}
.pf-save{
  min-height:48px;
  border-radius:16px!important;
  padding-left:22px!important;
  padding-right:22px!important;
}

/* Master cabinet */
.master-cabinet-shell{
  width:min(100%,1180px);
  margin:0 auto;
  padding:clamp(14px,2.4vw,30px);
}
.master-cabinet-hero{
  max-width:none;
  border-radius:28px;
  border:1px solid rgba(255,106,0,.14);
  background:
    radial-gradient(circle at 12% 10%,rgba(255,106,0,.20),rgba(255,106,0,0) 35%),
    linear-gradient(135deg,rgba(255,255,255,.94),rgba(255,247,239,.82));
  box-shadow:0 18px 46px rgba(15,23,42,.08);
  padding:clamp(18px,2.6vw,30px);
}
.master-cabinet-hero .mch-avatar{
  width:72px;
  height:72px;
  flex-basis:72px;
  border-radius:22px;
  font-size:26px;
  background:#fff;
  color:var(--cab-r34-orange);
}
.master-cabinet-hero .mch-title{
  font-size:clamp(24px,3vw,34px);
}
.master-cabinet-hero .mch-sub{
  font-size:clamp(13px,1.5vw,16px);
}
.master-cabinet-hero .mch-stat{
  border-radius:18px;
  background:rgba(255,255,255,.72);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.master-cabinet-hero .mch-actions .btn,
.master-cabinet-tile-nav .master-cabinet-tile{
  border-radius:18px!important;
}
.master-cabinet-shell__main{
  gap:clamp(16px,2.4vw,28px);
}
.master-cabinet-shell__navcol{
  min-width:0;
}
.master-cabinet-tile-nav{
  gap:12px;
}
.master-cabinet-tile-nav .master-cabinet-tile{
  box-shadow:0 8px 22px rgba(15,23,42,.055);
}
.master-cabinet-inline-panel{
  border-radius:26px;
}
.master-cabinet-inline-panel>.card,
.master-cabinet-inline-panel .card{
  border-radius:22px;
}

/* STO dashboard */
.sto-dispatch-page{
  width:min(100%,1180px);
  max-width:1180px!important;
  margin:0 auto;
  padding-left:clamp(14px,2.4vw,30px);
  padding-right:clamp(14px,2.4vw,30px);
}
.sto-dispatch-head{
  padding:clamp(18px,2.8vw,30px);
  border:1px solid rgba(255,106,0,.12);
  border-radius:28px;
  background:
    radial-gradient(circle at 12% 0%,rgba(255,106,0,.16),rgba(255,106,0,0) 42%),
    rgba(255,255,255,.86);
  box-shadow:var(--cab-r34-shadow);
}
.sto-dispatch-title{
  font-size:clamp(26px,3.2vw,38px);
  letter-spacing:-.045em;
}
.sto-dispatch-sub{
  font-size:clamp(13px,1.4vw,16px);
}
.sto-stat-grid{
  gap:clamp(12px,1.8vw,18px);
}
.sto-stat-card{
  border-radius:22px;
  background:#fff;
  border:1px solid var(--cab-r34-line);
  box-shadow:var(--cab-r34-soft-shadow);
  padding:clamp(14px,2vw,22px);
}
.sto-stat-val{
  font-size:clamp(24px,2.8vw,34px);
}
.sto-section{
  border-radius:24px;
  background:#fff;
  box-shadow:0 10px 30px rgba(15,23,42,.055);
}
.sto-section-head{
  padding:clamp(14px,2vw,20px) clamp(16px,2.4vw,24px);
}
.sto-section-title{
  font-size:clamp(15px,1.8vw,20px);
}
.sto-order-row,
.sto-master-row{
  padding:clamp(12px,1.8vw,18px) clamp(16px,2.4vw,24px);
}
.sto-order-actions .btn,
.sto-row-btn,
.sto-master-open{
  border-radius:14px!important;
}

@media (min-width:768px){
  .cab-hero .container,
  .cab-pane>.container{
    max-width:min(100% - 48px,1120px);
  }
  .cab-profile-row{
    display:grid;
    grid-template-columns:auto minmax(0,1fr) auto;
    align-items:center;
    gap:22px;
  }
  .cab-mini-stats--max3,
  .cab-mini-stats{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .cab-pane-layout{
    display:grid;
    grid-template-columns:minmax(0,1fr);
  }
  .profile-form{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:16px;
  }
  .profile-form .pf-group:nth-last-child(1),
  .profile-form > div:last-child{
    grid-column:1 / -1;
  }
  .cst-grid,
  .diag-account-grid,
  .loy-levels-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:16px;
  }
  .master-cabinet-shell__main{
    display:grid;
    grid-template-columns:minmax(240px,300px) minmax(0,1fr);
    align-items:start;
  }
  .master-cabinet-tile-nav{
    position:sticky;
    top:18px;
  }
  .sto-order-row.sto-dispatch-row{
    display:grid;
    grid-template-columns:40px minmax(0,1fr) minmax(220px,auto);
    align-items:center;
  }
}

@media (min-width:1024px){
  .cab-hero .container,
  .cab-pane>.container{
    max-width:min(100% - 72px,1240px);
  }
  .cab-profile-row{
    padding:30px;
  }
  .cab-name{
    font-size:clamp(28px,3vw,40px);
  }
  .cab-avatar,
  .cab-avatar--photo{
    width:92px!important;
    height:92px!important;
    font-size:32px!important;
  }
  .cab-mini-stats{
    max-width:760px;
    margin-left:auto;
    margin-right:auto;
  }
  .cst-grid,
  .diag-account-grid,
  .loy-levels-grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
  .profile-form-card{
    max-width:980px;
    margin:0 auto;
  }
  .master-cabinet-shell__main{
    grid-template-columns:310px minmax(0,1fr);
  }
  .master-cabinet-hero .mch-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .sto-stat-grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
}

@media (min-width:768px) and (orientation:landscape) and (max-height:760px){
  .cab-hero .container,
  .cab-pane>.container,
  .master-cabinet-shell,
  .sto-dispatch-page{
    max-width:min(100% - 32px,1180px);
  }
  .cab-profile-row,
  .master-cabinet-hero,
  .sto-dispatch-head{
    padding:16px 18px;
    border-radius:22px;
  }
  .master-cabinet-hero .mch-avatar,
  .cab-avatar,
  .cab-avatar--photo{
    width:58px!important;
    height:58px!important;
    flex-basis:58px!important;
  }
  .master-cabinet-hero .mch-grid,
  .cab-mini-stats{
    margin-top:10px;
  }
  .master-cabinet-shell__main{
    grid-template-columns:260px minmax(0,1fr);
  }
  .master-cabinet-tile-nav .master-cabinet-tile{
    min-height:74px;
    padding:10px 12px!important;
  }
}

@media (max-width:767px){
  .cab-profile-row{
    border-radius:22px;
    padding:16px;
  }
  .cab-pane>.container{
    max-width:100%;
  }
  .master-cabinet-shell,
  .sto-dispatch-page{
    padding-left:12px;
    padding-right:12px;
  }
  .master-cabinet-hero,
  .sto-dispatch-head{
    border-radius:22px;
  }
}
