:root {
  --brand-btn:#6964de;
  --brand-btn-text:#ECF6F8;
  --brand-page:#D8E1EB;
  --brand-border:#6D1EA6;
  --brand-shadow:0 2px 16px rgba(0,0,0,.08);
  --bg:var(--brand-page);
  --panel:#ffffff;
  --muted:#6b7280;
  --text:#111827;
  --accent:var(--brand-btn);
  --border:var(--brand-border);
  --danger:#b91c1c;
  --ok:#16a34a;
  --radius:10px;
  --bw:1px;
}

*{box-sizing:border-box}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font:14px/1.45 "Inter",system-ui,-apple-system,"Segoe UI",Roboto,Arial;
  padding-top:env(safe-area-inset-top,0);
  padding-bottom:env(safe-area-inset-bottom,0);
  padding-left:env(safe-area-inset-left,0);
  padding-right:env(safe-area-inset-right,0);
  min-height:100vh;
  min-height:-webkit-fill-available;
}
.wrap{max-width:1100px;margin:0 auto;padding:24px}
h1{font-family:"Nunito","Inter",system-ui;font-size:22px;margin:0}

.panel{background:var(--panel);border-radius:var(--radius);padding:24px;box-shadow:var(--brand-shadow)}
.row{display:flex;flex-direction:column;gap:12px}
.muted{color:var(--muted)}

.btn{
  cursor:pointer;
  border:var(--bw) solid var(--border);
  background:#ffffff;
  color:var(--text);
  padding:10px 14px;
  border-radius:var(--radius);
  transition:.2s;
  height:45px;
  font-size:18px;
}
.btn:hover{background:#f0f3fb;color:var(--text)}
.btn-primary{
  width: 100%;
  background:var(--accent);
  color:var(--brand-btn-text);
  border-color:var(--border);
  font-weight:600;
  height:45px;
  font-size:18px;
}
.btn-primary:hover{background:#7f7bd8;color:var(--brand-btn-text)}
.btn-primary[disabled]{
  opacity:.5;
  cursor:not-allowed;
  background-color:var(--accent);
}
.btn-danger{background:#3b0b12;border-color:#7a1322;color:#fff}

.grid{display:grid;gap:12px}
label.small{font-size:12px;display:block;margin-bottom:4px}
input[type="text"],input[type="tel"],input[type="file"],textarea{width:100%;background:#ffffff;border:var(--bw) solid var(--border);border-radius:var(--radius);padding:10px 12px;color:var(--text);outline:none}
input:focus,textarea:focus{border-color:#5c1a8c}
.hidden{display:none}
.mt{margin-top:12px}
.mt2{margin-top:18px}
.space-between{display:flex;justify-content:space-between;align-items:center;gap:10px}

.phone-group{display:flex;align-items:stretch;background:#ffffff;border:var(--bw) solid var(--border);border-radius:var(--radius);overflow:hidden}
.phone-group:focus-within{border-color:#5c1a8c}
.phone-group .prefix-wrap{position:relative;display:flex;align-items:center;border-right:var(--bw) solid var(--border);background:#ffffff}
.phone-group select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:transparent;border:none;color:var(--text);padding:8px 28px 8px 10px;min-width:130px;outline:none}
.phone-group select option{color:#0b0b0d;background:#ffffff}
.phone-group .chev{position:absolute;right:8px;pointer-events:none;color:var(--muted);font-size:12px}
.phone-group input{flex:1;background:transparent;border:none;color:var(--text);padding:8px 10px;outline:none}

.steps{display:flex;gap:10px;align-items:center;margin-bottom:5px;flex-wrap:nowrap}
.pill{
  flex:1 1 0;
  padding:8px 16px;
  border-radius:999px;
  background:#eef0fc;
  font-size:12px;
  font-weight:600;
  font-family:"Nunito","Inter",system-ui;
  color:#6b7280;
  line-height:1;
  transition:background .25s ease,color .25s ease;
  text-align:center;
  white-space:nowrap;
  display:flex;
  justify-content:center;
  align-items:center;
  min-width:0;
  min-height:30px;
}
.pill.completed{background:#cdd1f6;color:#1f2937}
.pill.active{background:#111827;color:#ffffff}

.step-tip{margin:0 0 12px;font-size:12px;color:#4b5563;font-style:italic}
.alert{padding:10px;border:var(--bw) solid var(--border);border-radius:var(--radius);background:#ffffff;box-shadow:var(--brand-shadow)}
.alert-danger{background:#fff0f0;border-color:#d14343;color:#7a1322}
.danger{color:#b45309}

.upload-zone{position:relative}
.upload-zone .drag{margin-top:6px}
.drag{border:var(--bw) dashed var(--border);border-radius:var(--radius);padding:18px;text-align:center;background:#ECF6F8;cursor:pointer;transition:background .2s ease,border-color .2s ease}
.drag.dragover{background:#e7f0f5;border-color:#5c1a8c}

.progress{position:relative;height:14px;background:#eef1f7;border:var(--bw) solid var(--border);border-radius:999px;overflow:hidden}
.progress-bar{position:absolute;left:0;top:0;height:100%;width:0%;background:#7f7bd8;transition:width .35s ease}
.progress-label{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:11px;color:#111827;font-weight:600;pointer-events:none}

.format-head{display:flex;align-items:center;justify-content:flex-start;color:#4b5563;margin-bottom:6px;font-size:12px;gap:8px}
.format-head .format-label{color:#4b5563;font-weight:600}
.cards-wrapper{position:relative;overflow:visible}
.cards-wrapper .swipe-inline{position:absolute;left:0;top:50%;display:inline-flex;align-items:center;justify-content:center;width:100%;color:#6b6f9f;transform:translate3d(0,-50%,0);animation:swipeInline 8s ease-in-out infinite;pointer-events:none;z-index:2;line-height:1}
.cards-wrapper .swipe-inline.hidden{display:none}
.cards-wrapper .swipe-inline i{font-size:40px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.2))}
@keyframes swipeInline{
  0%{opacity:1;transform:translate3d(0,-50%,0)}
  16%{transform:translate3d(calc(100% - 40px),-50%,0)}
  32%{transform:translate3d(0,-50%,0)}
  48%{transform:translate3d(calc(100% - 40px),-50%,0)}
  64%{transform:translate3d(0,-50%,0)}
  82%{transform:translate3d(calc(100% - 40px),-50%,0)}
  100%{opacity:1;transform:translate3d(0,-50%,0)}
}

.cards-track{display:flex;gap:12px;overflow-x:auto;overflow-y:hidden;padding:8px 0;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}
.cards-track::-webkit-scrollbar{height:6px}
.cards-track::-webkit-scrollbar-thumb{background:#c3c7e6;border-radius:999px}
.card{border:0;cursor:pointer;background:#ffffff;flex:0 0 140px;scroll-snap-align:start;transition:transform .2s ease;display:flex;flex-direction:column;outline:none;-webkit-tap-highlight-color:rgba(0,0,0,0)!important;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;touch-action:manipulation;-webkit-touch-callout:none;-webkit-appearance:none;appearance:none}
.card:active{background:#ffffff!important;outline:none!important;box-shadow:none!important;-webkit-tap-highlight-color:rgba(0,0,0,0)!important;transition:none!important}
.card:focus{outline:none!important;box-shadow:none!important}
.card:focus-visible{outline:none!important;box-shadow:none!important}
.card img{width:100%;display:block;object-fit:cover;border:var(--bw) solid var(--border);border-radius:var(--radius);pointer-events:none}
.card.active img{border-color:var(--accent);background:rgba(149,146,224,0.12)}
.card.active{transform:scale(1.05)}
.card.active img{opacity:0.95}

.drag.filled{border-style:solid;background:#fff0f5}
.drag .file-name{font-weight:600;color:var(--text);font-size:13px;word-break:break-word}

.gallery{display:flex;gap:10px;overflow:auto;padding-bottom:6px}
.cards-track, .gallery{cursor:grab;user-select:none;-webkit-user-select:none}
.cards-track:active, .gallery:active{cursor:grabbing}
.thumb{position:relative;width:110px;height:110px;min-width:110px;border:var(--bw) solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff}
.thumb.sm{width:80px;height:80px;min-width:80px}
.thumb img{width:110px;height:100%;object-fit:cover;display:block}
.thumb.sm img{width:80px;height:100%;object-fit:cover;display:block}
.badge{position:absolute;right:6px;bottom:6px;font-size:11px;padding:3px 6px;border-radius:8px;color:#fff}
.badge.ok{background:#16a34a}
.badge.bad{background:#e11d48}
.undo-btn{position:absolute;left:6px;top:6px;padding:4px 6px;border-radius:8px;background:#0f0f14cc;border:1px solid #2d2d33;color:#eaeaea;cursor:pointer;transition:background .2s ease}
.undo-btn:hover{background:#1a1a20}
.thumb-remove{position:absolute;right:6px;top:6px;padding:4px 6px;border-radius:8px;background:#0f0f14cc;border:1px solid #2d2d33;color:#eaeaea;cursor:pointer;transition:background .2s ease}
.thumb-remove:hover{background:#1a1a20}

.layout{display:flex;flex-direction:column;gap:12px}
.viewer{min-height:420px;border:var(--bw) solid var(--border);border-radius:var(--radius);background:#f5f7fb;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:var(--brand-shadow)}
.viewer img{max-width:100%;max-height:520px}
.side{border:var(--bw) solid var(--border);border-radius:var(--radius);padding:12px;background:#fff;box-shadow:var(--brand-shadow)}
.side .kv{font-size:12px;color:#4b5563}
.right-panel{position:absolute;right:12px;top:12px;background:#ffffff;border:var(--bw) solid var(--border);border-radius:var(--radius);padding:10px;width:220px;box-shadow:var(--brand-shadow)}
.right-panel input[type="range"]{width:100%}
.tool-panel{margin-top:8px;background:#ffffff;border:var(--bw) solid var(--border);border-radius:var(--radius);padding:10px;box-shadow:var(--brand-shadow)}
.tool-panel input[type="range"]{width:100%}
.checkbox{display:flex;gap:8px;align-items:center}

.modal-backdrop{position:fixed;inset:0;background:rgba(17,24,39,.55);display:flex;justify-content:center;align-items:center;padding:24px;z-index:30}
.modal-card{background:#ffffff;border:var(--bw) solid var(--border);border-radius:var(--radius);width:min(420px,100%);max-height:90vh;box-shadow:var(--brand-shadow);display:flex;flex-direction:column}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:var(--bw) solid var(--border)}
.modal-title{font-family:"Nunito","Inter",system-ui;font-weight:700;font-size:18px;color:var(--text)}
.modal-body{padding:16px;overflow:auto}
.list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.list li{padding:10px 12px;border-radius:var(--radius);border:var(--bw) dashed var(--border);background:#f7f9fc;font-size:13px;color:#374151}

/* Адаптивность для мобильных устройств и Telegram Mini App */
@media (max-width:768px){
  .wrap{
    padding:12px;
    padding-bottom:max(12px, env(safe-area-inset-bottom));
    padding-top:max(12px, env(safe-area-inset-top));
  }
  .panel{
    padding:16px;
    border-radius:12px;
  }
  h1{
    font-size:20px;
  }
  .step-tip{
    font-size:11px;
    line-height:1.5;
  }
  .btn{
    padding:12px 16px;
    font-size:18px;
    height:45px;
  }
  .pill{
    font-size:11px;
    padding:6px 12px;
  }
  .card{
    flex:0 0 120px;
    -webkit-tap-highlight-color:rgba(0,0,0,0)!important;
    -webkit-touch-callout:none!important;
    -webkit-appearance:none!important;
    appearance:none!important;
  }
  .card:active{
    background:#ffffff!important;
    opacity:1!important;
    box-shadow:none!important;
    -webkit-tap-highlight-color:rgba(0,0,0,0)!important;
    transform:none!important;
  }
  .card:focus{
    background:#ffffff!important;
    box-shadow:none!important;
  }
  .card.active:active{
    transform:scale(1.15)!important;
  }
  .card-title{
    font-size:11px;
    padding:8px 6px;
  }
  .thumb{
    width:110px;
    height:110px;
    min-width:110px;
  }
  .thumb.sm{
    width:80px;
    height:80px;
    min-width:80px;
  }
  .thumb img{
    width:110px;
  }
  .thumb.sm img{
    width:80px;
  }
  .viewer{
    min-height:300px;
  }
  .viewer img{
    max-height:400px;
  }
  .tool-panel{
    padding:12px;
  }
  .right-panel{
    width:100%;
    position:relative;
    right:auto;
    top:auto;
    margin-top:12px;
  }
  .layout{
    flex-direction:column;
  }
  .gallery{
    gap:8px;
  }
  .drag{
    padding:14px;
    font-size:13px;
  }
  input[type="text"],input[type="tel"],input[type="file"],textarea{
    padding:12px;
    font-size:16px; /* Предотвращает зум на iOS */
  }
  .modal-card{
    width:calc(100% - 32px);
    max-width:calc(100vw - 32px);
    margin:16px;
  }
  .modal-body{
    padding:12px;
  }
  .space-between{
    gap:8px;
  }
}

/* Очень маленькие экраны (до 480px) */
@media (max-width:480px){
  .wrap{
    padding:8px;
    padding-bottom:max(8px, env(safe-area-inset-bottom));
    padding-top:max(8px, env(safe-area-inset-top));
  }
  .panel{
    padding:12px;
  }
  h1{
    font-size:18px;
  }
  .card{
    flex:0 0 100px;
  }
  .thumb{
    width:110px;
    height:110px;
    min-width:110px;
  }
  .thumb.sm{
    width:80px;
    height:80px;
    min-width:80px;
  }
  .thumb img{
    width:110px;
  }
  .thumb.sm img{
    width:80px;
  }
  .viewer{
    min-height:250px;
  }
  .viewer img{
    max-height:350px;
  }
  .steps{
    gap:6px;
  }
  .pill{
    font-size:10px;
    padding:5px 10px;
  }
}

/* Telegram Mini App специфичные стили */
@supports (padding: max(0px)) {
  .wrap{
    padding-left:max(12px, env(safe-area-inset-left));
    padding-right:max(12px, env(safe-area-inset-right));
  }
}

/* Улучшенная прокрутка для мобильных */
@media (hover: none) and (pointer: coarse){
  .cards-track{
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;
  }
  .gallery{
    -webkit-overflow-scrolling:touch;
  }
  .btn:hover{
    background:#ffffff;
  }
  .btn-primary:hover{
    background:var(--accent);
  }
}