*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:#D24734;
  --red-dark:#A93527;
  --ink:#111827;
  --muted:#667085;
  --line:#E7EAF0;
  --soft:#F6F7FA;
  --soft-red:#FFF0ED;
  --white:#fff;
  --green:#0F8A5F;
  --shadow:0 24px 80px rgba(17,24,39,.10);
  --radius:22px;
  --heading:'Exo 2',sans-serif;
  --body:'Manrope',sans-serif;
}
html{font-size:16px;scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--body);color:var(--ink);background:linear-gradient(135deg,#fff 0%,#F7F8FB 52%,#FFF5F2 100%);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.hidden{display:none!important}
.skip-link{position:fixed;top:-56px;left:16px;z-index:100;background:var(--ink);color:#fff;padding:10px 14px;border-radius:10px;font-weight:800}
.skip-link:focus{top:16px}
:focus-visible{outline:3px solid rgba(210,71,52,.35);outline-offset:3px}

.portal-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:24px;width:100%;padding:14px clamp(18px,4vw,56px);background:rgba(255,255,255,.88);backdrop-filter:blur(20px);border-bottom:1px solid rgba(17,24,39,.07)}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--heading);font-size:1.3rem;font-weight:800;letter-spacing:.4px}
.brand img{width:46px;height:46px;border-radius:10px;object-fit:cover}
.brand b{color:var(--red)}
.portal-nav{display:flex;align-items:center;gap:18px;max-width:100%;font-weight:800;color:#344054}
.portal-nav a{padding:9px 10px;border-radius:10px;transition:.2s ease}
.portal-nav a:hover{background:var(--soft-red);color:var(--red)}

main{width:100%;max-width:1180px;margin:0 auto;padding:34px 18px 80px}
.portal-hero{display:grid;grid-template-columns:minmax(0,1.04fr) minmax(360px,.78fr);gap:28px;align-items:stretch;width:100%;max-width:100%;overflow:hidden}
.portal-hero>*,.dashboard-grid>*,.form-grid>*{min-width:0}
.hero-copy,.auth-card,.profile-card,.history-card,.appointment-form{width:100%;max-width:100%;min-width:0;overflow:hidden;background:rgba(255,255,255,.92);border:1px solid rgba(17,24,39,.08);border-radius:var(--radius);box-shadow:var(--shadow)}
.hero-copy{padding:clamp(30px,5vw,58px);position:relative;overflow:hidden}
.hero-copy::after{content:"";position:absolute;right:-120px;top:-120px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(210,71,52,.16),transparent 62%)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;background:var(--soft-red);color:var(--red);font-size:.78rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
h1,h2,h3{font-family:var(--heading);line-height:1.12;color:var(--ink)}
h1{font-size:clamp(2.4rem,5vw,4.7rem);max-width:780px;margin:22px 0 20px}
h2{font-size:clamp(1.8rem,3vw,2.8rem)}
h3{font-size:1.18rem}
h1,h2,h3,p,a,span,strong,dd,li{overflow-wrap:anywhere;word-break:break-word}
.hero-copy p{max-width:720px;color:var(--muted);font-size:1.05rem;overflow-wrap:break-word}
.hero-actions{display:none}

.auth-card{padding:28px;align-self:start}
.card-head{margin-bottom:22px}
.card-head h2{font-size:2rem;margin:14px 0 8px}
.card-head p,.field-hint,.form-footer p{color:var(--muted);font-size:.9rem;overflow-wrap:break-word}
.field-hint.success{color:var(--green)}
.field-hint.error{color:#B42318}
.status-pill{display:inline-flex;padding:6px 10px;border-radius:999px;background:#EEF7F2;color:var(--green);font-size:.72rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.status-pill.dev{background:#FFF7E8;color:#A15C00}

form label{display:grid;gap:8px;color:#344054;font-weight:800}
.phone-form,.otp-form{display:grid;gap:14px}
.phone-control{display:flex;align-items:center;border:1px solid var(--line);border-radius:16px;background:#fff;overflow:hidden;transition:.2s ease}
.phone-control:focus-within{border-color:rgba(210,71,52,.55);box-shadow:0 0 0 4px rgba(210,71,52,.10)}
.phone-prefix{align-self:stretch;display:flex;align-items:center;justify-content:center;flex:0 0 54px;min-width:54px;padding:0 12px;font-weight:900;line-height:1;white-space:nowrap;color:var(--red);border-right:1px solid var(--line)}
input,select,textarea{width:100%;border:1px solid var(--line);border-radius:16px;background:#fff;color:var(--ink);padding:14px 15px;transition:.2s ease}
.phone-control input{min-width:0;border:0;border-radius:0}
.vin-control{display:grid;grid-template-columns:minmax(0,1fr) 128px;gap:8px}
.vin-control input{text-transform:uppercase;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;letter-spacing:.04em}
.vin-lookup-btn{padding-inline:12px}
.plate-control{display:grid;grid-template-columns:minmax(0,1fr) 112px;border:1px solid var(--line);border-radius:16px;background:#fff;overflow:hidden;transition:.2s ease}
.plate-control:focus-within{border-color:rgba(210,71,52,.55);box-shadow:0 0 0 4px rgba(210,71,52,.10)}
.plate-control input,.plate-control select{min-width:0;border:0;border-radius:0;box-shadow:none}
.plate-control input{text-transform:uppercase}
.plate-control select{border-left:1px solid var(--line);font-weight:900;color:#344054;background:#F8FAFC;cursor:pointer}
input:focus,select:focus,textarea:focus{border-color:rgba(210,71,52,.55);box-shadow:0 0 0 4px rgba(210,71,52,.10);outline:none}
.plate-control input:focus,.plate-control select:focus{box-shadow:none}
textarea{resize:vertical;min-height:112px}
.primary-btn,.ghost-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:16px;border:0;padding:14px 18px;font-weight:900;transition:.2s ease}
.primary-btn{background:var(--red);color:#fff;box-shadow:0 14px 28px rgba(210,71,52,.24)}
.primary-btn:hover{background:var(--red-dark);transform:translateY(-1px)}
.primary-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.ghost-btn{background:var(--soft);color:#344054;border:1px solid var(--line)}
.ghost-btn:hover:not(:disabled){background:#fff;border-color:#CDD3DD}
.ghost-btn:disabled{opacity:.5;cursor:not-allowed}
.otp-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.notice{min-height:24px;margin-top:14px;color:var(--muted);font-weight:700}
.notice.success{color:var(--green)}
.notice.error{color:#B42318}
.auth-result{padding:16px;border-radius:16px;background:#EEF7F2;color:#175C43;margin-top:12px}
.auth-result p{color:#34745D}
.consent-check{display:flex;align-items:flex-start;gap:10px;color:var(--muted);font-size:.84rem;font-weight:700;line-height:1.45}
.consent-check input{flex:0 0 auto;width:18px;height:18px;margin-top:2px;padding:0;border-radius:4px;accent-color:var(--red)}
.consent-check a{color:var(--red);font-weight:900;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.optional-consent{padding:12px;border:1px solid rgba(15,138,95,.16);border-radius:14px;background:#F3FBF7;color:#2F6B57}

.account-section,.appointment-section{margin-top:34px}
.section-title-row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:18px}
.section-title-row>*{min-width:0;max-width:100%}
.section-title-row p{max-width:520px;color:var(--muted)}
.dashboard-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.profile-card,.history-card{padding:24px}
.history-card{grid-column:1/-1}
.card-note{color:var(--muted);font-size:.92rem;margin-top:8px}
.bonus-balance{font-family:var(--heading);font-size:2rem;font-weight:900;color:var(--red);margin-top:18px}
.preference-status{display:inline-flex;align-items:center;margin-top:16px;padding:8px 12px;border-radius:999px;background:#EEF7F2;color:var(--green);font-size:.78rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase}
.preference-status.disabled{background:#F2F4F7;color:#667085}
.small-action{margin-top:14px;padding:11px 14px;border-radius:12px}
.danger-action{border-color:rgba(180,35,24,.28);color:#B42318;background:#FFF1F0}
.danger-action:hover{background:#FEE4E2;color:#912018}
.account-deletion-card{border-color:rgba(180,35,24,.16)}
.account-deletion-form{display:grid;gap:10px;margin-top:12px}
.account-deletion-form textarea{width:100%;resize:vertical;min-height:88px;padding:12px 13px;border:1px solid var(--line);border-radius:14px;font:inherit;color:var(--ink);background:#fff}
.danger-consent{align-items:flex-start;color:#344054;font-size:.86rem}
.compact-notice{min-height:20px;margin-top:8px;font-size:.82rem}
.vehicles-card{grid-column:span 2}
.vehicles-list{display:grid;gap:10px;margin-top:14px}
.vehicle-chip-card{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:12px;border:1px solid var(--line);border-radius:14px;background:#fff}
.vehicle-chip-card strong{display:block;font-family:var(--heading);font-size:.98rem;color:var(--ink)}
.vehicle-chip-card span{display:block;margin-top:2px;color:var(--muted);font-size:.8rem}
.archive-vehicle-btn{min-height:36px;padding:8px 10px;border-radius:10px;font-size:.78rem}
.vehicle-profile-form{display:grid;gap:10px;margin-top:14px;padding:12px;border-radius:16px;background:var(--soft);border:1px solid rgba(17,24,39,.06)}
.vehicle-profile-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.vehicle-profile-grid input,.vehicle-profile-grid select{min-height:40px;padding:9px 10px;border-radius:11px;font-size:.86rem}
.vehicle-profile-vin{text-transform:uppercase;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace}
.compact-empty{margin-top:0}
dl{display:grid;gap:16px;margin-top:18px}
dl div{display:flex;justify-content:space-between;gap:18px;padding-bottom:12px;border-bottom:1px solid var(--line)}
dt{color:var(--muted)}
dd{font-weight:900;text-align:right}
.empty-state{margin-top:14px;padding:16px;border-radius:16px;background:var(--soft);color:var(--muted)}
.history-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}
.status-legend{display:flex;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:.82rem;font-weight:800}
.status-legend span{display:inline-flex;align-items:center;gap:6px}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot.open{background:#F79009}
.dot.closed{background:var(--green)}
.order-list{display:grid;gap:14px;margin-top:20px}
.order-card{display:grid;gap:16px;padding:18px;border:1px solid var(--line);border-radius:18px;background:#fff}
.order-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.order-date{font-family:var(--heading);font-weight:900;color:var(--red)}
.order-title{font-family:var(--heading);font-size:1.16rem;font-weight:900;margin-top:4px}
.order-subtitle,.order-meta,.reviewed-note{color:var(--muted);font-size:.9rem}
.order-source{color:#667085;font-size:.78rem;font-weight:800;margin-top:4px;text-transform:uppercase;letter-spacing:.04em}
.order-status{display:inline-flex;align-items:center;gap:7px;white-space:nowrap;padding:7px 10px;border-radius:999px;font-size:.74rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase}
.order-status.open{background:#FFF7E8;color:#A15C00}
.order-status.closed{background:#EEF7F2;color:var(--green)}
.works-list{display:grid;gap:8px;padding:14px;border-radius:14px;background:var(--soft)}
.works-list li{margin-left:18px;color:#344054}
.order-footer{display:flex;align-items:center;justify-content:space-between;gap:14px;border-top:1px solid var(--line);padding-top:14px}
.order-amount{font-weight:900;color:#344054}
.bonus-earned{font-weight:900;color:var(--green)}
.review-panel{display:grid;gap:12px;border-top:1px solid var(--line);padding-top:14px}
.review-form{display:grid;gap:12px;padding:14px;border-radius:16px;background:var(--soft)}
.rating-control{display:grid;grid-template-columns:140px 1fr;gap:12px;align-items:center}
.review-actions{display:flex;justify-content:flex-end}
.review-toggle{padding:11px 14px;border-radius:12px}

.appointment-form{padding:28px;display:grid;gap:24px}
fieldset{border:0;display:grid;gap:16px}
legend{font-family:var(--heading);font-size:1.25rem;font-weight:800;margin-bottom:12px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.field-vin{grid-column:1/-1}
.field-saved-vehicle{grid-column:1/-1}
.wide-label{margin-top:4px}
.form-footer{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-top:18px;border-top:1px solid var(--line)}
.form-consent,.optional-consent{max-width:720px}
.portal-footer{width:100%;max-width:1180px;margin:0 auto 34px;padding:22px 18px 0;border-top:1px solid rgba(17,24,39,.09);display:flex;align-items:flex-start;justify-content:space-between;gap:18px;color:var(--muted);font-size:.86rem}
.portal-footer strong{display:block;color:var(--ink);font-family:var(--heading);font-size:1rem}
.portal-footer span{display:block;margin-top:3px}
.legal-links{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap;font-weight:900}
.legal-links a{color:#344054}
.legal-links a:hover{color:var(--red)}


.corporate-client-card{grid-column:1/-1;display:grid;gap:14px}
.corporate-client-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.corporate-client-list{display:grid;gap:14px}
.corporate-account-box{display:grid;gap:14px;padding:16px;border:1px solid rgba(210,71,52,.18);border-radius:18px;background:linear-gradient(135deg,#fff,#FFF7F5)}
.corporate-account-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.corporate-account-top strong{display:block;font-family:var(--heading);font-size:1.15rem;color:var(--ink)}
.corporate-account-top span{display:block;margin-top:3px;color:var(--muted);font-size:.84rem;font-weight:800}
.corporate-status{display:inline-flex!important;margin-top:0!important;padding:7px 10px;border-radius:999px;background:#EEF7F2;color:var(--green)!important;font-size:.72rem!important;font-weight:900!important;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.corporate-requisites-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.detail-mini{display:grid;gap:4px;padding:11px 12px;border:1px solid rgba(17,24,39,.07);border-radius:14px;background:#fff}
.detail-mini span{color:var(--muted);font-size:.72rem;font-weight:900;text-transform:uppercase;letter-spacing:.04em}
.detail-mini strong{font-size:.88rem;color:#344054}
.corporate-metrics{display:flex;gap:8px;flex-wrap:wrap}
.corporate-metrics span{display:inline-flex;padding:7px 10px;border-radius:999px;background:#fff;border:1px solid var(--line);color:#344054;font-size:.78rem;font-weight:900}
.corporate-columns{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.corporate-delete-action{justify-self:flex-start;margin-top:2px}
.corporate-columns h4{font-family:var(--heading);font-size:.98rem;margin-bottom:8px;color:var(--ink)}
.corporate-vehicle-row,.corporate-order-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:11px 12px;border:1px solid var(--line);border-radius:14px;background:#fff}
.corporate-vehicle-row+.corporate-vehicle-row,.corporate-order-row+.corporate-order-row{margin-top:8px}
.corporate-vehicle-row strong,.corporate-order-row strong{display:block;font-size:.9rem;color:var(--ink)}
.corporate-vehicle-row span,.corporate-order-row span{display:block;color:var(--muted);font-size:.78rem;font-weight:800}
.corporate-vehicle-row>span{color:var(--green);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em}
.corporate-order-row>div:last-child{display:grid;justify-items:end;gap:4px}
.corporate-order-row em{font-style:normal;color:#344054;font-size:.78rem;font-weight:900;white-space:nowrap}
.mini-status{display:inline-flex!important;padding:5px 8px;border-radius:999px;font-size:.68rem!important;font-weight:900!important;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.mini-status.open{background:#FFF7E8;color:#A15C00!important}
.mini-status.closed{background:#EEF7F2;color:var(--green)!important}

@media(max-width:920px){
  .portal-hero{grid-template-columns:1fr}
  .dashboard-grid,.form-grid,.corporate-requisites-grid,.corporate-columns{grid-template-columns:1fr}
  .section-title-row,.form-footer,.history-head,.order-top,.order-footer,.portal-footer{align-items:flex-start;flex-direction:column}
}
@media(max-width:640px){
  html{scroll-padding-top:86px}
  body{line-height:1.45}
  .portal-header{align-items:center;flex-direction:row;gap:10px;padding:9px 12px}
  .brand{gap:8px;font-size:1.05rem}
  .brand img{width:38px;height:38px;border-radius:8px}
  .portal-nav{width:auto;margin-left:auto;justify-content:flex-end;gap:4px;flex-wrap:wrap;overflow:visible;padding-bottom:2px;font-size:.86rem}
  .portal-nav a{flex:0 0 auto;padding:7px 5px;white-space:nowrap}
  main{width:100%;padding:14px 12px 60px}
  .portal-hero{gap:12px}
  main>section,.portal-hero,.hero-copy,.auth-card,.appointment-section,.account-section,.appointment-form,.profile-card,.history-card{min-width:0;max-width:100%}
  .hero-copy,.auth-card,.profile-card,.history-card{border-radius:18px;padding:16px}
  .appointment-form{border-radius:18px;padding:16px;gap:16px}
  .hero-copy::after{width:180px;height:180px;right:-80px;top:-80px}
  h1{font-size:1.76rem;margin:14px 0 10px}
  h2{font-size:1.42rem}
  h3{font-size:1.04rem}
  .eyebrow{padding:5px 9px;font-size:.66rem}
  .hero-copy p,.card-head p,.field-hint{font-size:.86rem;line-height:1.38}
  .hero-actions{display:grid;grid-template-columns:1fr;gap:8px;margin-top:14px}
  .hero-actions .primary-btn,.hero-actions .ghost-btn{min-height:42px;padding:10px 9px;border-radius:12px;font-size:.86rem}
  .auth-card{padding-top:14px}
  .card-head{margin-bottom:14px}
  .card-head h2{font-size:1.55rem;margin:10px 0 5px}
  .phone-form,.otp-form{gap:10px}
  .phone-control{border-radius:13px}
  .phone-prefix{flex-basis:48px;min-width:48px}
  input,select,textarea{padding:11px 12px;border-radius:13px}
  .primary-btn,.ghost-btn{min-height:44px;padding:11px 13px;border-radius:13px}
  .consent-check{gap:8px;font-size:.78rem;line-height:1.32}
  .otp-actions{grid-template-columns:1fr}
  .account-section,.appointment-section{margin-top:18px}
  .section-title-row{gap:9px;margin-bottom:12px}
  .section-title-row .ghost-btn{width:auto}
  .appointment-section .section-title-row{gap:8px;margin-bottom:12px}
  .appointment-section .section-title-row p{font-size:.88rem;line-height:1.35}
  .appointment-form fieldset{gap:10px;padding-bottom:14px;border-bottom:1px solid var(--line)}
  .appointment-form fieldset:last-of-type{padding-bottom:0;border-bottom:0}
  .appointment-form legend{font-size:1.04rem;margin-bottom:6px}
  .appointment-form label{gap:5px;font-size:.86rem}
  .appointment-form input,.appointment-form select,.appointment-form textarea{min-height:44px;padding:10px 11px;border-radius:12px;font-size:.94rem}
  .appointment-form textarea{min-height:76px}
  .appointment-form .form-grid{gap:10px}
  .vin-control{grid-template-columns:minmax(0,1fr) 104px;gap:7px}
  .vin-control input{font-size:.84rem;letter-spacing:.02em}
  .vin-lookup-btn{padding-inline:8px;font-size:.82rem}
  .vehicle-grid{grid-template-columns:92px minmax(0,1fr)}
  .field-vin,.field-brand,.field-model{grid-column:1/-1}
  .field-year{grid-column:1}
  .field-plate{grid-column:2}
  .service-grid{grid-template-columns:1fr 1fr}
  .field-service,.field-urgency,.wide-label{grid-column:1/-1}
  .field-date,.field-time{grid-column:auto}
  .contact-grid{grid-template-columns:1fr}
  .field-client-name,.field-contact-channel{grid-column:1/-1}
  .plate-control{grid-template-columns:minmax(0,1fr) 78px}
  .plate-control input,.plate-control select{min-height:44px;padding:10px 8px;font-size:.86rem}
  .field-plate .field-hint{display:none}
  .form-footer{gap:12px;padding-top:14px}
  .form-footer .primary-btn{width:100%}
  .form-consent,.optional-consent{font-size:.78rem;line-height:1.34}
  .optional-consent{padding:10px;border-radius:12px}
  .dashboard-grid{gap:10px}
  .profile-card,.history-card{padding:15px}
  .vehicles-card,.corporate-client-card{grid-column:1/-1}
  .vehicle-chip-card{grid-template-columns:1fr;gap:8px;padding:10px;border-radius:12px}
  .archive-vehicle-btn{width:100%;min-height:38px}
  .vehicle-profile-form{padding:10px;border-radius:13px}
  .vehicle-profile-grid{grid-template-columns:1fr 1fr;gap:7px}
  .vehicle-profile-grid .vehicle-profile-vin{grid-column:1/-1}
  .vehicle-profile-grid input,.vehicle-profile-grid select{min-height:39px;font-size:.82rem}

  .corporate-account-box{padding:12px;border-radius:14px;gap:11px}
  .corporate-account-top{flex-direction:column;gap:8px}
  .corporate-status{white-space:normal}
  .detail-mini{padding:9px 10px;border-radius:12px}
  .corporate-metrics span{font-size:.72rem;padding:6px 8px}
  .corporate-vehicle-row,.corporate-order-row{grid-template-columns:1fr;padding:10px;border-radius:12px}
  .corporate-order-row>div:last-child{justify-items:start}
  .bonus-balance{font-size:1.42rem;margin-top:10px}
  .preference-status{margin-top:10px;padding:7px 10px;font-size:.68rem}
  .small-action{width:100%;min-height:40px;margin-top:10px;padding:9px 11px;font-size:.84rem}
  .compact-notice{font-size:.76rem;line-height:1.3}
  .card-note{font-size:.82rem;line-height:1.34;margin-top:5px}
  dl{gap:9px;margin-top:10px}
  dl div{gap:10px;padding-bottom:8px}
  dt,dd{font-size:.86rem}
  .empty-state{margin-top:9px;padding:11px;border-radius:12px;font-size:.86rem;line-height:1.35}
  .history-head{gap:8px}
  .status-legend{gap:10px}
  .order-list{gap:10px;margin-top:12px}
  .order-card{gap:10px;padding:12px;border-radius:14px}
  .order-title{font-size:1rem}
  .order-subtitle,.order-meta,.reviewed-note{font-size:.82rem}
  .order-source{font-size:.7rem}
  .order-status{padding:6px 8px;font-size:.68rem}
  .works-list{gap:5px;padding:10px;border-radius:12px}
  .order-footer{gap:9px;padding-top:10px}
  .review-panel,.review-form{gap:9px;padding-top:10px}
  .review-form{padding:10px;border-radius:12px}
  .rating-control{grid-template-columns:1fr}
  .review-actions{justify-content:stretch}
  .review-actions .primary-btn{width:100%}
  .portal-footer{padding:18px 12px 0;font-size:.8rem}
}

/* Order details with diagnostics + client-side approval (2026-05-17 A.2) */
.order-details-toggle{margin-top:10px}
.order-details-toggle .ghost-btn{font-size:13px}
.order-details-block{margin-top:10px;padding:12px;background:rgba(0,0,0,0.04);border-radius:8px;display:flex;flex-direction:column;gap:12px}
.repair-block h4{margin:0 0 6px;font-size:14px}
.repair-block p{margin:0;color:#475569;font-size:14px}
.repair-block-pending{padding:12px;border:1px solid #f97316;background:#fff7ed;border-radius:8px}
.repair-inspect-list,.repair-items-list,.repair-pending-list{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}
.repair-inspect-item{padding:8px 10px;background:#fff;border-radius:6px;border-left:3px solid #94a3b8;font-size:14px}
.repair-inspect-item.repair-cond-attention{border-left-color:#f97316}
.repair-inspect-item.repair-cond-critical{border-left-color:#ef4444}
.repair-pending-item{padding:10px;background:#fff;border-radius:6px;border:1px solid #fde68a}
.repair-pending-head{display:flex;justify-content:space-between;font-size:14px;gap:8px}
.repair-pending-head em{font-style:normal;font-weight:700}
.repair-pending-actions{display:flex;gap:8px;margin-top:8px}
.repair-pending-actions .primary-btn{padding:8px 14px;font-size:13px}
.repair-pending-actions .ghost-btn{padding:8px 14px;font-size:13px}
.repair-items-list li{font-size:14px;padding:4px 0;border-bottom:1px dashed rgba(0,0,0,0.06)}
.repair-pill{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;background:#e2e8f0;color:#475569;margin-left:6px}
.repair-pill[data-status="awaiting_approval"]{background:#fed7aa;color:#9a3412}
.repair-pill[data-status="approved"]{background:#bbf7d0;color:#166534}
.repair-pill[data-status="rejected"]{background:#fecaca;color:#991b1b}
.repair-pill[data-status="done"]{background:#bbf7d0;color:#166534}
.muted{color:#94a3b8}
.notice--error{color:#dc2626}

/* Cabinet recommendations (2026-05-17 follow-up to A.2) */
.recommendations-list{display:flex;flex-direction:column;gap:10px}
.recommendation-item{padding:12px 14px;background:#fff;border-radius:8px;border-left:3px solid #94a3b8;border-top:1px solid #e2e8f0;border-right:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0}
.recommendation-item[data-priority="high"]{border-left-color:#f97316}
.recommendation-item[data-priority="urgent"]{border-left-color:#ef4444;background:#fff7ed}
.recommendation-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:4px}
.recommendation-head h4{margin:0;font-size:15px}
.recommendation-pill{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;background:#e2e8f0;color:#475569;white-space:nowrap}
.recommendation-pill[data-priority="high"]{background:#fed7aa;color:#9a3412}
.recommendation-pill[data-priority="urgent"]{background:#fecaca;color:#991b1b}
.recommendation-item p{margin:0 0 4px;font-size:14px;color:#475569}
.recommendation-meta{font-size:12px;color:#94a3b8}

/* Attachments gallery in client cabinet (2026-05-17) */
.repair-attachments{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-top:8px}
.repair-att-image{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px;background:#fff;border-radius:6px;border:1px solid #e2e8f0;text-decoration:none;color:#1e293b}
.repair-att-image img{max-width:100%;max-height:140px;border-radius:4px}
.repair-att-caption{font-size:12px;color:#475569;text-align:center}
.repair-att-doc{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:#fff;border-radius:6px;border:1px solid #e2e8f0;text-decoration:none;color:#1e293b;font-size:13px}

/* Phone-number change flow in profile card (2026-05-17) */
.profile-actions{margin-top:12px;display:flex;gap:8px}
.phone-change-flow{margin-top:14px;padding:14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:12px}
.phone-change-flow.hidden{display:none}
.phone-change-step{display:flex;flex-direction:column;gap:10px;margin:0}
.phone-change-step.hidden{display:none}
.phone-change-step p{margin:0;font-size:14px;color:#334155}
.phone-change-step label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:#475569}
.phone-change-step input[type=text],.phone-change-step input[type=tel]{padding:10px 12px;background:#fff;border:1px solid #cbd5e1;border-radius:6px;font:inherit}
.phone-change-step .consent-row{flex-direction:row;align-items:flex-start;gap:8px;font-size:13px;color:#475569}
.phone-change-step .consent-row input{margin-top:3px}
.phone-change-step .primary-btn{align-self:flex-start}
.phone-change-step .ghost-btn{align-self:flex-start}
.notice--success{color:#166534}

/* Onboarding wizard (2026-05-17 Item 2) */
.onboarding-section.hidden{display:none}
.onboarding-section{padding:30px 16px;background:linear-gradient(180deg,#fff,#f8fafc)}
.onboarding-card{max-width:680px;margin:0 auto;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:28px;box-shadow:0 4px 20px rgba(0,0,0,0.04)}
.onboarding-card h2{margin:0 0 6px;font-size:24px}
.onboarding-card>p{color:#475569;margin:0 0 18px}
.onboarding-types{border:0;padding:0;margin:0 0 18px;display:flex;flex-direction:column;gap:10px}
.onboarding-types legend{font-size:13px;font-weight:600;color:#475569;margin-bottom:8px;padding:0;text-transform:uppercase;letter-spacing:.4px}
.onboarding-type{display:flex;align-items:flex-start;gap:12px;padding:14px;border:1px solid #cbd5e1;border-radius:10px;cursor:pointer;transition:background 0.15s,border-color 0.15s}
.onboarding-type:hover{background:#f1f5f9}
.onboarding-type input[type=radio]{margin-top:3px}
.onboarding-type input[type=radio]:checked+span strong{color:#d83a3a}
.onboarding-type input[type=radio]:checked~*{}
.onboarding-type:has(input:checked){border-color:#d83a3a;background:#fff7f7}
.onboarding-type strong{display:block;font-size:15px;margin-bottom:2px}
.onboarding-type small{color:#64748b;font-size:13px}
.onboarding-field{display:flex;flex-direction:column;gap:4px;margin-bottom:16px;font-size:13px;color:#475569}
.onboarding-field input{padding:10px 12px;background:#fff;border:1px solid #cbd5e1;border-radius:6px;font:inherit}
.onboarding-corp{border:1px solid #e2e8f0;background:#f8fafc;padding:16px;border-radius:10px;margin-bottom:16px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.onboarding-corp.hidden{display:none}
.onboarding-corp legend{grid-column:1/-1;font-size:13px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.4px}
.onboarding-corp label{display:flex;flex-direction:column;gap:3px;font-size:12px;color:#475569}
.onboarding-corp input{padding:8px 10px;background:#fff;border:1px solid #cbd5e1;border-radius:6px;font:inherit;font-size:14px}
.onboarding-corp .onboarding-corp-vat{flex-direction:row;align-items:center;gap:8px}
.onboarding-corp .onboarding-corp-kpp.hidden,.onboarding-corp .onboarding-corp-vat.hidden{display:none}
@media (max-width:560px){.onboarding-corp{grid-template-columns:1fr}}

/* Warranty section (2026-05-17 Item 3) */
.warranty-list{display:flex;flex-direction:column;gap:14px}
.warranty-group{padding:12px;background:#fff;border:1px solid #e2e8f0;border-radius:10px}
.warranty-group__head{display:flex;align-items:baseline;gap:10px;margin-bottom:8px}
.warranty-group__head strong{font-size:15px}
.warranty-group__head small{color:#94a3b8;font-size:13px;font-family:monospace}
.warranty-items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.warranty-item{padding:10px 12px;border-radius:8px;background:#f8fafc;border-left:3px solid #94a3b8}
.warranty-item[data-status="active"]{border-left-color:#22c55e}
.warranty-item[data-status="expiring"]{border-left-color:#f97316;background:#fff7ed}
.warranty-item[data-status="expired"]{border-left-color:#94a3b8;opacity:0.7}
.warranty-item__head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;font-size:14px;margin-bottom:4px}
.warranty-item__head strong{flex:1}
.warranty-item__meta{font-size:12px;color:#64748b;display:flex;gap:12px;flex-wrap:wrap}
.warranty-pill{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;background:#e2e8f0;color:#475569;white-space:nowrap}
.warranty-pill[data-status="active"]{background:#bbf7d0;color:#166534}
.warranty-pill[data-status="expiring"]{background:#fed7aa;color:#9a3412}
.warranty-pill[data-status="expired"]{background:#e2e8f0;color:#64748b}
.warranty-kind{font-weight:600}
