/* ============================================================
   BKRENT — Design System v2
   Dark Premium Outdoor + Fintech Trust
   (c) 2025-2026 TSC Protektor
   ============================================================ */

:root {
  --bg: #0e1117;
  --surface: #151a25;
  --surface2: #1a2030;
  --surface3: #1f2535;
  --border: rgba(255,255,255,0.07);
  --border-hover: rgba(255,255,255,0.15);
  --teal: #0D7377;
  --teal-light: #0ea5e9;
  --cyan: #22d3ee;
  --amber: #E8A020;
  --amber-hover: #CC8C1A;
  --green: #22c55e;
  --red: #ef4444;
  --white: #ffffff;
  --gray: #94a3b8;
  --gray2: #64748b;
  --text: #e2e8f0;
  --font-h: 'Oswald', sans-serif;
  --font-b: 'Inter', system-ui, sans-serif;
  --r: 14px;
  --r2: 20px;
  --r3: 28px;
  --shadow-sm: 0 1px 4px rgba(0,0,0,.4);
  --shadow: 0 4px 20px rgba(0,0,0,.5);
  --shadow-md: 0 8px 40px rgba(0,0,0,.6);
  --transition: 0.25s ease;
}

/* --- Reset --- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font-b);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--teal-light);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--cyan)}
ul,ol{list-style:none}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--gray2)}
*{scrollbar-width:thin;scrollbar-color:var(--surface3) var(--bg)}

/* --- Typography --- */
h1,h2,h3,h4,h5,h6{font-family:var(--font-h);font-weight:700;line-height:1.15;letter-spacing:0.02em;text-transform:uppercase;color:var(--white)}
h1{font-size:clamp(2.5rem,6vw,5rem)}
h2{font-size:clamp(1.75rem,4vw,3rem)}
h3{font-size:clamp(1.25rem,3vw,1.75rem)}
h4{font-size:clamp(1.1rem,2.5vw,1.35rem)}
h5{font-size:1.1rem}
h6{font-size:0.95rem}
p{font-size:1rem;line-height:1.65;color:var(--gray);max-width:65ch}
.text-sm{font-size:0.875rem}.text-xs{font-size:0.75rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}
.text-muted{color:var(--gray2)}.text-white{color:var(--white)}.text-amber{color:var(--amber)}.text-teal{color:var(--teal-light)}.text-center{text-align:center}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-b);font-weight:600;font-size:0.9375rem;padding:12px 28px;border:none;border-radius:var(--r);cursor:pointer;transition:all var(--transition);min-height:44px;min-width:44px;text-decoration:none;line-height:1.2;white-space:nowrap}
.btn-primary{background:var(--teal);color:var(--white);box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--teal-light);box-shadow:var(--shadow);transform:translateY(-1px);color:var(--white)}
.btn-amber{background:var(--amber);color:#1a1a1a;font-weight:700;box-shadow:0 4px 20px rgba(232,160,32,0.3)}
.btn-amber:hover{background:var(--amber-hover);box-shadow:0 6px 28px rgba(232,160,32,0.4);transform:translateY(-2px);color:#1a1a1a}
.btn-ghost{background:transparent;color:var(--white);border:1.5px solid var(--border-hover)}
.btn-ghost:hover{border-color:var(--white);background:rgba(255,255,255,0.05);color:var(--white)}
.btn-danger{background:var(--red);color:var(--white)}
.btn-danger:hover{background:#dc2626;box-shadow:0 4px 20px rgba(239,68,68,0.3);transform:translateY(-1px)}
.btn-sm{padding:8px 18px;font-size:0.8125rem;min-height:36px}
.btn-lg{padding:16px 36px;font-size:1.0625rem;border-radius:var(--r2)}

/* --- Navigation --- */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(16px,4vw,48px);height:72px;background:rgba(14,17,23,0.85);backdrop-filter:blur(20px) saturate(1.5);-webkit-backdrop-filter:blur(20px) saturate(1.5);border-bottom:1px solid var(--border);transition:background var(--transition)}
.nav--scrolled{background:rgba(14,17,23,0.95);box-shadow:var(--shadow)}
.nav-logo{display:flex;align-items:center;gap:10px;color:var(--white);font-family:var(--font-h);font-size:1.5rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;text-decoration:none;flex-shrink:0}
.nav-logo:hover{color:var(--white)}
.nav-logo svg{width:32px;height:32px;flex-shrink:0}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{color:var(--gray);font-size:0.875rem;font-weight:500;transition:color var(--transition);text-decoration:none;position:relative}
.nav-links a:hover{color:var(--white)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--teal-light);transition:width var(--transition)}
.nav-links a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:12px}

/* Burger */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;background:none;border:none;cursor:pointer;z-index:1010}
.burger span{display:block;width:100%;height:2px;background:var(--white);border-radius:2px;transition:all var(--transition);transform-origin:center}
.burger--open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger--open span:nth-child(2){opacity:0}
.burger--open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile Menu - hidden by default */
.mob-menu{position:fixed;top:0;right:-100%;width:100%;max-width:360px;height:100vh;height:100dvh;background:var(--surface);z-index:1005;padding:96px 24px 24px;transition:right 0.35s cubic-bezier(0.4,0,0.2,1);overflow-y:auto;box-shadow:var(--shadow-md)}
.mob-menu--open{right:0}
.mob-menu a{display:block;padding:16px 0;font-family:var(--font-h);font-size:1.35rem;text-transform:uppercase;letter-spacing:0.04em;color:var(--text);border-bottom:1px solid var(--border);text-decoration:none;transition:color var(--transition)}
.mob-menu a:hover{color:var(--amber)}
.mob-menu-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:1002;opacity:0;pointer-events:none;transition:opacity 0.35s ease}
.mob-menu-backdrop--open{opacity:1;pointer-events:all}

/* --- Cards --- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;transition:all var(--transition);box-shadow:var(--shadow-sm)}
.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow);transform:translateY(-4px)}
.card-body{padding:20px}
.card-title{font-family:var(--font-h);font-size:1.15rem;font-weight:600;color:var(--white);text-transform:uppercase;letter-spacing:0.03em;margin-bottom:8px}
.card-text{font-size:0.9rem;color:var(--gray);line-height:1.5}
.card-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card--bike .card-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.card--bike .card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease}
.card--bike:hover .card-img img{transform:scale(1.05)}
.card--bike .card-img .badge{position:absolute;top:12px;left:12px}
.card-price{font-family:var(--font-h);font-size:1.4rem;color:var(--amber);font-weight:700}
.card-price span{font-family:var(--font-b);font-size:0.8rem;color:var(--gray2);font-weight:400}

/* --- Status Badges --- */
.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;font-size:0.75rem;font-weight:600;border-radius:100px;text-transform:uppercase;letter-spacing:0.04em;white-space:nowrap}
.badge::before{content:'';width:7px;height:7px;border-radius:50%;flex-shrink:0}
.badge-available{background:rgba(34,197,94,0.12);color:var(--green)}
.badge-available::before{background:var(--green);box-shadow:0 0 6px var(--green)}
.badge-rented{background:rgba(239,68,68,0.12);color:var(--red)}
.badge-rented::before{background:var(--red)}
.badge-repair{background:rgba(232,160,32,0.12);color:var(--amber)}
.badge-repair::before{background:var(--amber)}
.badge-pending{background:rgba(148,163,184,0.12);color:var(--gray)}
.badge-pending::before{background:var(--gray)}
.badge-soon{background:rgba(14,165,233,0.12);color:var(--teal-light)}
.badge-soon::before{background:var(--teal-light);animation:pulse 2s infinite}

/* --- Tab Bar --- */
.tab-bar{position:fixed;bottom:0;left:0;right:0;z-index:900;display:none;align-items:flex-end;justify-content:space-around;height:64px;background:var(--surface);border-top:1px solid var(--border);padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0px)}
.tab-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1;height:100%;font-size:0.625rem;font-weight:500;color:var(--gray2);text-decoration:none;transition:color var(--transition);cursor:pointer;background:none;border:none;min-width:44px;min-height:44px}
.tab-item:hover,.tab-item--active{color:var(--teal-light)}
.tab-item svg{width:22px;height:22px}
.tab-item--qr{position:relative;flex:0 0 64px}
.tab-item--qr .tab-qr-btn{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--teal-light));color:var(--white);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(13,115,119,0.4);border:3px solid var(--surface);transition:all var(--transition);cursor:pointer}
.tab-item--qr .tab-qr-btn:hover{transform:translateX(-50%) scale(1.08);box-shadow:0 6px 28px rgba(13,115,119,0.5)}
.tab-item--qr .tab-qr-btn svg{width:26px;height:26px}

/* --- App Shell --- */
.app-shell{min-height:100vh;display:flex;flex-direction:column}
.app-shell .app-content{flex:1;padding:80px 16px 80px}
.app-shell .tab-bar{display:flex}

/* --- Bottom Sheet --- */
.bottom-sheet-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:1100;opacity:0;pointer-events:none;transition:opacity 0.3s ease}
.bottom-sheet-backdrop--open{opacity:1;pointer-events:all}
.bottom-sheet{position:fixed;bottom:0;left:0;right:0;z-index:1110;background:var(--surface);border-radius:var(--r3) var(--r3) 0 0;max-height:85vh;overflow-y:auto;transform:translateY(100%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);padding:12px 24px 32px;box-shadow:0 -8px 40px rgba(0,0,0,0.5)}
.bottom-sheet--open{transform:translateY(0)}
.bottom-sheet-handle{width:40px;height:4px;border-radius:2px;background:var(--gray2);margin:0 auto 20px}
.bottom-sheet-title{font-family:var(--font-h);font-size:1.25rem;color:var(--white);margin-bottom:16px;text-transform:uppercase;letter-spacing:0.03em}

/* --- Skeleton --- */
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skeleton{background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:800px 100%;animation:shimmer 1.5s infinite linear;border-radius:var(--r)}
.skeleton-text{height:14px;margin-bottom:10px;border-radius:6px}
.skeleton-text:last-child{width:60%}
.skeleton-img{aspect-ratio:4/3;border-radius:var(--r)}
.skeleton-avatar{width:48px;height:48px;border-radius:50%}

/* --- System States --- */
.state-loading,.state-empty,.state-error,.state-offline{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;gap:16px}
.state-loading svg,.state-empty svg,.state-error svg,.state-offline svg{width:64px;height:64px;color:var(--gray2)}
.state-loading p,.state-empty p,.state-error p,.state-offline p{color:var(--gray);max-width:40ch;margin:0 auto}
.state-loading .spinner{width:40px;height:40px;border:3px solid var(--surface3);border-top-color:var(--teal-light);border-radius:50%;animation:spin 0.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.state-error svg{color:var(--red)}
.state-offline svg{color:var(--amber)}

/* --- Offline Banner --- */
.offline-banner{position:fixed;top:0;left:0;right:0;z-index:2000;background:var(--amber);color:#1a1a1a;text-align:center;padding:10px 16px;font-size:0.8125rem;font-weight:600;transform:translateY(-100%);transition:transform 0.3s ease}
.offline-banner--visible{transform:translateY(0);animation:offlinePulse 3s infinite}
@keyframes offlinePulse{0%,100%{opacity:1}50%{opacity:0.85}}

/* --- Footer --- */
.footer{background:var(--surface);border-top:1px solid var(--border);padding:28px clamp(16px,5vw,64px) 32px}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;max-width:1200px;margin:0 auto}
.footer-col h4{font-family:var(--font-h);font-size:0.95rem;color:var(--white);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:16px}
.footer-col p,.footer-col a{font-size:0.875rem;color:var(--gray);line-height:1.8;display:block;text-decoration:none;transition:color var(--transition)}
.footer-col a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid var(--border);margin-top:40px;padding-top:20px;text-align:center;font-size:0.8125rem;color:var(--gray2);max-width:1200px;margin-left:auto;margin-right:auto}

/* --- Mini Programs --- */
.mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.mini-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);padding:24px 16px;text-align:center;transition:all var(--transition);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:10px;min-height:120px}
.mini-card:hover{border-color:var(--border-hover);background:var(--surface2);transform:translateY(-3px);box-shadow:var(--shadow)}
.mini-card-icon{width:48px;height:48px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:rgba(13,115,119,0.12);color:var(--teal-light)}
.mini-card-title{font-family:var(--font-h);font-size:0.85rem;color:var(--white);text-transform:uppercase;letter-spacing:0.04em}
.mini-card--soon{opacity:0.5;pointer-events:none;position:relative}
.mini-card--soon::after{content:'СКОРО';position:absolute;top:8px;right:8px;font-size:0.6rem;font-weight:700;color:var(--teal-light);background:rgba(14,165,233,0.15);padding:2px 8px;border-radius:100px;letter-spacing:0.08em}

/* --- Forms --- */
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:0.8125rem;font-weight:500;color:var(--gray);margin-bottom:6px;letter-spacing:0.02em}
.form-input{width:100%;padding:12px 16px;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--r);color:var(--text);font-family:var(--font-b);font-size:0.9375rem;transition:all var(--transition);outline:none;min-height:44px}
.form-input::placeholder{color:var(--gray2)}
.form-input:focus{border-color:var(--teal-light);box-shadow:0 0 0 3px rgba(14,165,233,0.15)}
.form-input:hover{border-color:var(--border-hover)}
.form-error{font-size:0.75rem;color:var(--red);margin-top:4px;display:flex;align-items:center;gap:4px}
textarea.form-input{resize:vertical;min-height:120px}
select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}

/* --- Chatbot --- */
.chatbot-btn{position:fixed;bottom:24px;right:24px;z-index:800;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--teal-light));color:var(--white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(13,115,119,0.4);transition:all var(--transition)}
.chatbot-btn:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(13,115,119,0.5)}
.chatbot-btn svg{width:24px;height:24px}

/* --- Animations --- */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(1.2)}}
.animate-fade-in{animation:fadeIn 0.5s ease both}
.animate-slide-up{animation:slideUp 0.5s ease both}
[data-animate]{opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease}
[data-animate].visible{opacity:1;transform:translateY(0)}

/* --- Operator Panel --- */
.operator-header{background:var(--surface);border-bottom:1px solid var(--border);padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.operator-header h2{font-size:1.25rem;margin:0}
.operator-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:16px;display:flex;align-items:center;gap:16px;transition:all var(--transition)}
.operator-card:hover{border-color:var(--border-hover);background:var(--surface3)}
.client-preview-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);padding:20px;display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center}
.client-preview-card .avatar{width:48px;height:48px;border-radius:50%;background:var(--surface3);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--teal-light);font-size:1.1rem}
.client-preview-card .info h4{font-size:1rem;margin-bottom:2px;text-transform:none}
.client-preview-card .info p{font-size:0.8125rem;color:var(--gray2)}

/* --- Utility --- */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 clamp(16px,4vw,48px)}
.section{padding:80px 0}
.section-header{text-align:center;margin-bottom:48px}
.section-header h2{margin-bottom:12px}
.section-header p{margin:0 auto;max-width:50ch}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.flex-center{display:flex;align-items:center;justify-content:center}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.gap-32{gap:32px}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-48{margin-top:48px}
.hidden{display:none !important}

/* --- Responsive --- */
@media(max-width:768px){
  .nav-links,.nav-actions{display:none !important}
  .burger{display:flex}
  .section{padding:48px 0}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .mini-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .btn-lg{width:100%}
  h1{font-size:clamp(2rem,8vw,3rem)}
  .chatbot-btn{bottom:80px}
}
@media(min-width:769px) and (max-width:1024px){
  .nav-links{gap:20px}
  .nav-links a{font-size:0.8125rem}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .section{padding:64px 0}
}
@media(max-width:374px){
  html{font-size:14px}
  .mini-grid{grid-template-columns:1fr 1fr}
  .nav{padding:0 12px}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
}

/* ================================================================
   BKRENT Operator + Admin + Mini-app — Extended Styles
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap');

/* ─── Stat Cards ─────────────────────────────────────────────── */
.stat-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .75rem;
}
.stat-card {
    background: var(--surface);
    border-radius: var(--r);
    border: 1px solid var(--border);
    padding: 1rem;
    text-align: center;
}
.stat-value {
    display: block;
    font-family: var(--font-h);
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--white);
    line-height: 1.2;
}
.stat-value.teal { color: var(--teal-light); }
.stat-value.amber { color: var(--amber); }
.stat-value.red { color: var(--red); }
.stat-value.green { color: var(--green); }

.stat-label {
    display: block;
    font-size: .72rem;
    color: var(--gray2);
    margin-top: .25rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    font-weight: 500;
}

.stat-delta {
    font-size: .72rem;
    font-weight: 600;
    margin-top: .15rem;
}
.stat-delta.up { color: var(--green); }
.stat-delta.down { color: var(--red); }

/* ─── Operator Header ────────────────────────────────────────── */
.op-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 0;
    z-index: 100;
}
.op-header-left {
    display: flex;
    align-items: center;
    gap: .75rem;
}
.op-logo {
    font-family: var(--font-h);
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--white);
    letter-spacing: .08em;
}
.op-logo span { color: var(--teal); }
.op-title {
    font-size: .68rem;
    color: var(--gray2);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: 500;
}
.op-header-right {
    display: flex;
    align-items: center;
    gap: .75rem;
}
.op-user {
    font-size: .78rem;
    color: var(--gray);
}
.op-logout {
    font-size: .7rem;
    color: var(--red);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    cursor: pointer;
    background: rgba(239,68,68,.1);
    border: 1px solid rgba(239,68,68,.2);
    border-radius: 6px;
    padding: .3rem .6rem;
    font-family: var(--font-b);
    transition: background var(--transition);
}
.op-logout:hover { background: rgba(239,68,68,.2); }

/* ─── Content Wrapper ────────────────────────────────────────── */
.op-content {
    padding: 1rem 1.25rem 6rem;
    max-width: 600px;
    margin: 0 auto;
}

/* ─── Section Title ──────────────────────────────────────────── */
.section-title {
    font-family: var(--font-b);
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--gray2);
    margin: 1.5rem 0 .75rem;
}

/* ─── Action Buttons ─────────────────────────────────────────── */
.action-buttons {
    display: flex;
    flex-direction: column;
    gap: .6rem;
    margin-top: .5rem;
}

/* ─── Extended Button Styles ─────────────────────────────────── */
.btn-teal {
    background: var(--teal) !important;
    color: var(--white) !important;
}
.btn-teal:hover { background: var(--teal-light) !important; box-shadow: 0 0 30px rgba(13,115,119,.3); }
.btn-teal:active { transform: scale(0.98); }

.btn-red {
    background: var(--red) !important;
    color: var(--white) !important;
}
.btn-red:hover { background: #dc2626 !important; }

.btn-green {
    background: var(--green) !important;
    color: #000 !important;
}
.btn-green:hover { background: #16a34a !important; }

.btn-full { width: 100%; }
.btn-lg {
    min-height: 64px !important;
    font-size: 1rem !important;
    padding: 1rem 1.5rem !important;
    font-family: var(--font-h) !important;
    letter-spacing: .06em;
    text-transform: uppercase;
}

/* ─── Rental Cards ───────────────────────────────────────────── */
.rental-card {
    display: flex;
    align-items: center;
    gap: .75rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: .85rem 1rem;
    margin-bottom: .6rem;
    transition: border-color var(--transition);
}
.rental-card:hover { border-color: var(--border-hover); }

.rental-id {
    font-family: var(--font-h);
    font-size: .72rem;
    color: var(--teal-light);
    font-weight: 600;
    letter-spacing: .06em;
    white-space: nowrap;
}
.rental-info { flex: 1; min-width: 0; }
.rental-name {
    font-weight: 600;
    font-size: .88rem;
    color: var(--white);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.rental-sub {
    font-size: .72rem;
    color: var(--gray2);
    margin-top: 2px;
}
.rental-timer {
    font-family: var(--font-h);
    font-size: 1rem;
    color: var(--amber);
    letter-spacing: .04em;
    white-space: nowrap;
}
.rental-price {
    font-family: var(--font-h);
    font-size: .88rem;
    color: var(--white);
    white-space: nowrap;
}
.rental-action .btn {
    min-height: 36px !important;
    padding: .4rem .7rem !important;
    font-size: .68rem !important;
}

/* ─── Sync Bar ───────────────────────────────────────────────── */
.sync-bar {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    padding: .75rem 1.25rem;
    background: var(--surface);
    border-top: 1px solid var(--border);
    display: flex;
    justify-content: center;
    z-index: 50;
}

/* ─── Scanner ────────────────────────────────────────────────── */
.scanner-container {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background: var(--bg);
}
.scanner-header {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: 1rem 1.25rem;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
}
.scanner-back {
    font-size: .85rem;
    color: var(--gray);
    cursor: pointer;
    padding: .35rem;
    text-decoration: none;
}
.scanner-back:hover { color: var(--white); }

.scanner-viewport {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}
.scanner-frame {
    width: 260px;
    height: 260px;
    border: 2px solid var(--teal);
    border-radius: var(--r2);
    position: relative;
    margin-bottom: 1.5rem;
    background: rgba(13,115,119,.05);
}
.scanner-frame::before,
.scanner-frame::after {
    content: '';
    position: absolute;
    width: 40px; height: 40px;
    border-color: var(--teal);
    border-style: solid;
}
.scanner-frame::before { top:-1px; left:-1px; border-width:3px 0 0 3px; border-radius: 12px 0 0 0; }
.scanner-frame::after  { top:-1px; right:-1px; border-width:3px 3px 0 0; border-radius: 0 12px 0 0; }
.scanner-frame .corner-bl,
.scanner-frame .corner-br {
    position: absolute;
    width: 40px; height: 40px;
    border-color: var(--teal);
    border-style: solid;
}
.scanner-frame .corner-bl { bottom:-1px; left:-1px; border-width:0 0 3px 3px; border-radius: 0 0 0 12px; }
.scanner-frame .corner-br { bottom:-1px; right:-1px; border-width:0 3px 3px 0; border-radius: 0 0 12px 0; }

.scan-line {
    position: absolute;
    top: 20px; left: 20px; right: 20px;
    height: 2px;
    background: var(--teal);
    box-shadow: 0 0 12px var(--teal);
    animation: scanMove 2s ease-in-out infinite;
}
@keyframes scanMove {
    0%, 100% { top: 20px; }
    50% { top: calc(100% - 22px); }
}

.scanner-hint {
    font-size: .85rem;
    color: var(--gray2);
    text-align: center;
    margin-bottom: 1rem;
}

/* ─── Client Profile ─────────────────────────────────────────── */
.client-profile {
    padding: 1.5rem 1.25rem 2rem;
    max-width: 500px;
    margin: 0 auto;
    width: 100%;
    animation: fadeUp .4s ease;
}
@keyframes fadeUp {
    from { opacity:0; transform:translateY(16px); }
    to { opacity:1; transform:translateY(0); }
}

.client-avatar {
    width: 80px; height: 80px;
    border-radius: 50%;
    background: var(--surface2);
    border: 3px solid var(--teal);
    margin: 0 auto 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: var(--teal-light);
}
.client-name {
    font-family: var(--font-h);
    font-size: 1.5rem;
    color: var(--white);
    text-align: center;
    letter-spacing: .04em;
}
.client-phone {
    font-size: .88rem;
    color: var(--gray);
    text-align: center;
    margin-top: .25rem;
}
.client-status {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    margin: .75rem auto;
    padding: .35rem .8rem;
    border-radius: 100px;
    font-size: .78rem;
    font-weight: 600;
}
.client-status.verified { background: rgba(34,197,94,.12); color: var(--green); border: 1px solid rgba(34,197,94,.25); }
.client-status.unverified { background: rgba(239,68,68,.12); color: var(--red); border: 1px solid rgba(239,68,68,.25); }

.client-rental-info {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 1rem;
    margin: 1rem 0;
    text-align: center;
}
.client-rental-label {
    font-size: .72rem;
    color: var(--gray2);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: 500;
    margin-bottom: .35rem;
}
.client-rental-detail {
    font-family: var(--font-h);
    font-size: 1.1rem;
    color: var(--white);
    letter-spacing: .03em;
}

.client-actions {
    display: flex;
    flex-direction: column;
    gap: .6rem;
    margin-top: 1.25rem;
}

/* ─── Loading Spinner ────────────────────────────────────────── */
.loader {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    padding: 3rem;
}
.loader-spinner {
    width: 40px; height: 40px;
    border: 3px solid var(--border);
    border-top-color: var(--teal);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}
.loader-text {
    font-size: .85rem;
    color: var(--gray2);
}

/* ─── Admin Layout ───────────────────────────────────────────── */
.admin-layout {
    display: flex;
    min-height: 100vh;
}

.admin-sidebar {
    width: 240px;
    background: var(--surface);
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0; bottom: 0; left: 0;
    z-index: 200;
    transition: transform .3s ease;
}
.admin-sidebar-header {
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--border);
}
.admin-sidebar-logo {
    font-family: var(--font-h);
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--white);
    letter-spacing: .08em;
}
.admin-sidebar-logo span { color: var(--teal); }

.admin-nav-list {
    padding: .75rem 0;
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: thin;
    scrollbar-color: var(--teal) transparent;
}
.admin-nav-item {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .7rem 1.5rem;
    font-size: .88rem;
    color: var(--gray);
    font-weight: 500;
    transition: all var(--transition);
    cursor: pointer;
    border-left: 3px solid transparent;
    text-decoration: none;
}
.admin-nav-item:hover {
    color: var(--white);
    background: rgba(255,255,255,.03);
}
.admin-nav-item.active {
    color: var(--white);
    background: rgba(13,115,119,.1);
    border-left-color: var(--teal);
}
.admin-nav-item .nav-icon {
    font-size: 1.1rem;
    width: 24px;
    text-align: center;
}

.admin-main {
    flex: 1;
    margin-left: 240px;
    padding: 1.5rem 2rem 3rem;
    min-height: 100vh;
}

.admin-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
}
.admin-topbar h1 {
    font-size: 1.6rem;
}
.admin-topbar-date {
    font-size: .82rem;
    color: var(--gray2);
}

.admin-burger {
    display: none;
    position: fixed;
    top: 1rem; left: 1rem;
    z-index: 300;
    width: 44px; height: 44px;
    border-radius: 10px;
    background: var(--surface);
    border: 1px solid var(--border);
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 1.3rem;
    color: var(--gray);
}
.admin-burger:hover { color: var(--white); border-color: var(--border-hover); }

.admin-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.6);
    z-index: 150;
}

/* KPI Grid */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: .75rem;
    margin-bottom: 1.5rem;
}
.kpi-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 1.25rem;
}
.kpi-label {
    font-size: .72rem;
    color: var(--gray2);
    text-transform: uppercase;
    letter-spacing: .06em;
    font-weight: 500;
}
.kpi-value {
    font-family: var(--font-h);
    font-size: 2rem;
    font-weight: 700;
    color: var(--white);
    margin-top: .35rem;
    line-height: 1.1;
}
.kpi-delta {
    font-size: .75rem;
    font-weight: 600;
    margin-top: .25rem;
}
.kpi-delta.up { color: var(--green); }
.kpi-delta.down { color: var(--red); }

/* Chart Card */
.chart-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}
.chart-card h3 { margin-bottom: 1rem; }

/* Admin Table */
.admin-table-wrap {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    overflow-x: auto;
    overflow-y: visible;
    margin-bottom: 1.5rem;
    -webkit-overflow-scrolling: touch;
}
.admin-table-wrap .admin-table {
    min-width: 700px;
}
.admin-table-wrap--users .admin-table {
    min-width: 1020px;
}
.admin-table-wrap--users td:last-child {
    white-space: nowrap;
    min-width: 150px;
}
.admin-table-wrap--users .admin-btn {
    padding: .2rem .5rem;
    font-size: .75rem;
}
.admin-table-wrap h3 {
    padding: 1rem 1.25rem .75rem;
}
.admin-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .85rem;
}
.admin-table thead th {
    text-align: left;
    padding: .6rem 1rem;
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--gray2);
    border-bottom: 1px solid var(--border);
    font-family: var(--font-b);
}
.admin-table tbody td {
    padding: .7rem 1rem;
    border-bottom: 1px solid var(--border);
    color: var(--gray);
}
.admin-table tbody tr:last-child td { border-bottom: none; }
.admin-table tbody tr:hover { background: rgba(255,255,255,.02); }

/* Status Badge (extended) */
.badge-active { background: rgba(13,115,119,.15); color: var(--teal-light); }
.badge-active::before { background: var(--teal-light); box-shadow: 0 0 6px var(--teal-light); }
.badge-done { background: rgba(34,197,94,.12); color: var(--green); }
.badge-done::before { background: var(--green); }
.badge-busy { background: rgba(239,68,68,.12); color: var(--red); }
.badge-busy::before { background: var(--red); }

/* Attention Block */
.attention-block {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    padding: 1.25rem;
}
.attention-block h3 { margin-bottom: .75rem; }
.attention-item {
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .5rem 0;
    font-size: .85rem;
    color: var(--gray);
}
.attention-item:not(:last-child) { border-bottom: 1px solid var(--border); }
.attention-icon {
    width: 32px; height: 32px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    flex-shrink: 0;
}
.attention-icon.amber { background: rgba(232,160,32,.12); }
.attention-icon.red { background: rgba(239,68,68,.12); }

/* ─── Admin Components ───────────────────────────────────────── */

/* Page wrapper */
.admin-page { display: flex; flex-direction: column; gap: 1.25rem; }
.admin-page__header {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: .75rem; margin-bottom: .25rem;
}

/* Headings */
.admin-h1 {
    font-family: var(--font-h);
    font-size: 1.5rem; font-weight: 600;
    color: var(--white); margin: 0;
}
.admin-h2 {
    font-family: var(--font-b);
    font-size: .95rem; font-weight: 600;
    color: var(--gray); text-transform: uppercase;
    letter-spacing: .06em; margin: 0 0 1rem;
}
.admin-count {
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,.07); color: var(--gray2);
    font-size: .72rem; font-weight: 600; font-family: var(--font-b);
    border-radius: 99px; padding: .15rem .55rem; margin-left: .4rem;
    vertical-align: middle;
}

/* Card */
.admin-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    padding: 1.25rem 1.5rem;
}

/* Form */
.admin-form { width: 100%; }
.admin-form__row {
    display: flex; flex-wrap: wrap; gap: .75rem; align-items: flex-end;
}
.admin-form__group { display: flex; flex-direction: column; gap: .35rem; min-width: 160px; flex: 1; }
.admin-form__group label { font-size: .78rem; font-weight: 500; color: var(--gray2); }
.admin-form__group--submit { flex: 0 0 auto; min-width: auto; }

/* Inputs */
.admin-input, .admin-select {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text);
    font-family: var(--font-b);
    font-size: .85rem;
    padding: .5rem .75rem;
    transition: border-color var(--transition);
    outline: none;
}
.admin-input:focus, .admin-select:focus { border-color: var(--teal); }
.admin-select--full { width: 100%; }
.admin-input::placeholder { color: var(--gray2); }

/* Buttons */
.admin-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: .35rem;
    padding: .42rem .85rem;
    border-radius: 7px;
    font-size: .78rem; font-weight: 600; font-family: var(--font-b);
    border: 1px solid transparent;
    cursor: pointer; transition: all var(--transition);
    white-space: nowrap; text-decoration: none;
    background: var(--surface2); color: var(--gray);
    border-color: var(--border);
}
.admin-btn:hover { color: var(--white); border-color: var(--border-hover); }
.admin-btn--sm { padding: .28rem .6rem; font-size: .72rem; }
.admin-btn--primary { background: rgba(13,115,119,.15); color: var(--teal-light); border-color: rgba(13,115,119,.3); }
.admin-btn--primary:hover { background: rgba(13,115,119,.25); color: var(--cyan); }
.admin-btn--green { background: rgba(34,197,94,.1); color: var(--green); border-color: rgba(34,197,94,.25); }
.admin-btn--green:hover { background: rgba(34,197,94,.2); }
.admin-btn--red { background: rgba(239,68,68,.08); color: var(--red); border-color: rgba(239,68,68,.2); }
.admin-btn--red:hover { background: rgba(239,68,68,.18); }
.admin-btn--yellow { background: rgba(232,160,32,.1); color: var(--amber); border-color: rgba(232,160,32,.25); }
.admin-btn--yellow:hover { background: rgba(232,160,32,.2); }
.admin-btn--gray { background: rgba(100,116,139,.1); color: var(--gray2); border-color: rgba(100,116,139,.2); }
.admin-btn--gray:hover { background: rgba(100,116,139,.2); color: var(--gray); }

/* Badges */
.admin-badge {
    display: inline-block;
    padding: .2rem .55rem;
    border-radius: 99px;
    font-size: .72rem; font-weight: 600;
    background: rgba(255,255,255,.05); color: var(--gray2);
}
.admin-badge--active { background: rgba(34,197,94,.1); color: var(--green); }
.admin-badge--blocked { background: rgba(239,68,68,.1); color: var(--red); }
.admin-badge--admin { background: rgba(232,160,32,.1); color: var(--amber); }
.admin-badge--mod { background: rgba(14,165,233,.1); color: var(--teal-light); }
.admin-badge--client { background: rgba(255,255,255,.05); color: var(--gray); }
.admin-badge--available { background: rgba(34,197,94,.1); color: var(--green); }
.admin-badge--rented { background: rgba(232,160,32,.1); color: var(--amber); }
.admin-badge--maintenance { background: rgba(239,68,68,.1); color: var(--red); }
.admin-badge--repair-open { background: rgba(239,68,68,.15); color: var(--red); border: 1px solid rgba(239,68,68,.3); }
.admin-badge--repair-in_progress { background: rgba(232,160,32,.15); color: var(--amber); border: 1px solid rgba(232,160,32,.3); }
.admin-badge--repair-completed { background: rgba(34,197,94,.1); color: var(--green); border: 1px solid rgba(34,197,94,.2); }
.admin-badge--sm { font-size: .72rem; padding: .2rem .5rem; }

/* Admin filters */
.admin-filters { display: flex; gap: .5rem; flex-wrap: wrap; }
.admin-filter-btn {
    padding: .35rem .85rem; border-radius: 20px; font-size: .82rem; font-weight: 500;
    background: var(--surface2); color: var(--gray); border: 1px solid var(--border);
    text-decoration: none; transition: all var(--transition);
}
.admin-filter-btn:hover { border-color: var(--teal); color: var(--teal-light); }
.admin-filter-btn.active { background: rgba(13,115,119,.2); color: var(--teal-light); border-color: var(--teal); }

/* ─── Repair info card ───────────────────────────────────────── */
.repair-info-card {
    display: flex; gap: 1.5rem; background: var(--surface);
    border: 1px solid var(--border); border-radius: 12px;
    padding: 1.5rem; margin-bottom: 1.25rem;
}
.repair-info-card__data { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: .5rem; }
.repair-info-card__img {
    width: 220px; flex-shrink: 0; display: flex; flex-direction: column;
    align-items: center; gap: .75rem;
}
.repair-info-card__img img {
    width: 100%; max-width: 220px; height: 160px; object-fit: cover;
    border-radius: 10px; border: 1px solid var(--border);
}
.repair-info-card__model-name {
    font-size: .82rem; color: var(--gray); text-align: center; font-weight: 500;
}
.repair-img-placeholder {
    width: 100%; height: 160px; background: var(--surface2); border-radius: 10px;
    border: 1px solid var(--border); display: flex; align-items: center;
    justify-content: center; font-size: 3.5rem;
}
.repair-info-row { display: flex; gap: .75rem; align-items: baseline; }
.repair-info-label {
    font-size: .78rem; color: var(--gray2); min-width: 110px; flex-shrink: 0;
}
.repair-info-value { font-size: .88rem; color: var(--text); }

/* Fault description box — prominent highlight */
.repair-fault-box {
    margin-top: .75rem;
    background: rgba(239,68,68,.08);
    border: 1px solid rgba(239,68,68,.35);
    border-left: 4px solid var(--red);
    border-radius: 10px;
    padding: 1rem 1.1rem;
}
.repair-fault-box__label {
    display: flex; align-items: center; gap: .4rem;
    font-size: .78rem; font-weight: 700; color: var(--red);
    text-transform: uppercase; letter-spacing: .04em; margin-bottom: .5rem;
}
.repair-fault-box__text {
    font-size: .95rem; color: var(--text); line-height: 1.55; white-space: pre-wrap;
}

/* ─── Repair history in repair_update page ───────────────────── */
.repair-history-list { display: flex; flex-direction: column; gap: 0; }
.repair-history-item {
  padding: 6px 0; border-bottom: 1px solid var(--border);
  font-size: .85rem; color: var(--gray2);
  display: flex; gap: 12px; align-items: center;
}
.repair-history-item:last-child { border-bottom: none; }
.repair-history-item--current { background: rgba(13,115,119,.06); border-radius: 6px; padding: 6px 8px; }
.repair-history-item .rh-date { min-width: 80px; color: var(--gray); font-size: .78rem; flex-shrink: 0; }
.repair-history-item .rh-status { min-width: 90px; font-weight: 600; font-size: .82rem; flex-shrink: 0; }
.repair-history-item .rh-desc { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hidden-item { display: none !important; }

/* ─── История ремонтов: аккордеон ───────────────────────────── */
.rh-accordion__toggle {
    width: 100%; display: flex; align-items: center; gap: .6rem;
    background: none; border: none; cursor: pointer; padding: 0; text-align: left;
    color: inherit;
}
.rh-accordion__toggle:hover .admin-h2 { color: var(--teal-light); }
.rh-accordion__count {
    font-size: .78rem; background: rgba(13,115,119,.2); color: var(--teal-light);
    border-radius: 4px; padding: .15rem .45rem; font-weight: 600;
}
.rh-accordion__arrow {
    margin-left: auto; transition: transform .25s ease; flex-shrink: 0;
    color: var(--gray2);
}
.rh-accordion__toggle[aria-expanded="true"] .rh-accordion__arrow {
    transform: rotate(180deg);
}
.rh-accordion__body {
    display: none; overflow: hidden;
}
.rh-accordion__body.open { display: block; }

/* ─── Repair history in bikes table ─────────────────────────── */
.repair-history-row td { background: var(--bg) !important; }
.repair-history-inline { padding: 1rem 1.5rem 1.25rem; border-top: 1px solid var(--border); }
.repair-history-inline__title {
    font-size: .8rem; font-weight: 700; color: var(--gray);
    text-transform: uppercase; letter-spacing: .04em; margin-bottom: .75rem;
}
.repair-history-inline__list { display: flex; flex-direction: column; gap: .6rem; }
.repair-history-inline__item {
    background: var(--surface); border: 1px solid var(--border); border-radius: 8px;
    padding: .75rem 1rem;
}
.repair-history-inline__meta { display: flex; align-items: center; gap: .6rem; margin-bottom: .3rem; flex-wrap: wrap; }
.repair-history-inline__date { font-size: .78rem; color: var(--gray2); }
.repair-history-inline__desc { font-size: .85rem; color: var(--text); margin-bottom: .25rem; }
.repair-history-inline__notes { font-size: .8rem; color: var(--gray); margin-top: .2rem; }

/* ─── Voice input controls ───────────────────────────────────── */
.voice-field-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: .4rem; gap: 1rem; flex-wrap: wrap; }
.voice-field-header label { font-weight: 500; color: var(--text); font-size: .88rem; }
.voice-controls { display: flex; gap: .5rem; }
.voice-btn, .voice-play-btn {
    display: inline-flex; align-items: center; gap: .35rem;
    padding: .3rem .75rem; border-radius: 20px; font-size: .78rem; font-weight: 600;
    border: 1px solid var(--border); cursor: pointer; transition: all var(--transition);
    background: var(--surface2); color: var(--gray); white-space: nowrap;
}
.voice-btn svg, .voice-play-btn svg { width: 14px; height: 14px; flex-shrink: 0; }
.voice-btn:hover { border-color: var(--red); color: var(--red); }
.voice-btn--recording {
    background: rgba(239,68,68,.15); border-color: var(--red); color: var(--red);
    animation: pulse-red 1.2s ease-in-out infinite;
}
.voice-play-btn { color: var(--teal-light); border-color: rgba(13,115,119,.4); }
.voice-play-btn:hover { background: rgba(13,115,119,.15); }
.voice-clear-btn, .voice-btn--clear {
    display: inline-flex; align-items: center; gap: .35rem;
    padding: .3rem .75rem; border-radius: 20px; font-size: .78rem; font-weight: 600;
    border: 1px solid rgba(239,68,68,.4); cursor: pointer; transition: all var(--transition);
    background: var(--surface2); color: var(--gray); white-space: nowrap;
}
.voice-clear-btn:hover, .voice-btn--clear:hover { background: rgba(239,68,68,.12); color: var(--red); border-color: var(--red); }
.voice-clear-btn svg, .voice-btn--clear svg { width: 14px; height: 14px; flex-shrink: 0; }
@keyframes pulse-red {
    0%, 100% { box-shadow: 0 0 0 0 rgba(239,68,68,.4); }
    50% { box-shadow: 0 0 0 5px rgba(239,68,68,0); }
}
.voice-status { font-size: .75rem; min-height: 1rem; margin-bottom: .25rem; }
.voice-status--active { color: var(--red); font-weight: 600; }
.voice-status--done { color: var(--green); }
.voice-status--error { color: var(--amber); }

/* Repair form helpers */
.admin-form-full .admin-textarea {
    width: 100%; background: var(--surface2); border: 1px solid var(--border);
    border-radius: 8px; color: var(--text); font-family: inherit; font-size: .88rem;
    padding: .65rem .85rem; resize: vertical; outline: none; transition: border-color var(--transition);
}
.admin-form-full .admin-textarea:focus { border-color: var(--teal); }
.admin-repair-next-service { font-size: .75rem; color: var(--amber); margin-top: .2rem; }

@media (max-width: 768px) {
    .repair-info-card { flex-direction: column-reverse; }
    .repair-info-card__img { width: 100%; }
    .repair-info-card__img img { max-width: 100%; height: 180px; }
    .voice-field-header { flex-direction: column; align-items: flex-start; }
}

/* Search */
.admin-search { display: flex; gap: .5rem; align-items: center; }
.admin-search__input {
    background: var(--surface2); border: 1px solid var(--border);
    border-radius: 8px; color: var(--text); font-size: .83rem;
    padding: .45rem .75rem; outline: none; width: 220px;
    transition: border-color var(--transition);
}
.admin-search__input:focus { border-color: var(--teal); }
.admin-search__btn {
    padding: .45rem .85rem; border-radius: 8px;
    background: rgba(13,115,119,.15); color: var(--teal-light);
    border: 1px solid rgba(13,115,119,.3); font-size: .82rem; font-weight: 600;
    cursor: pointer; transition: all var(--transition);
}
.admin-search__btn:hover { background: rgba(13,115,119,.25); }
.admin-search__clear {
    color: var(--gray2); font-size: .8rem; text-decoration: none; padding: .2rem .3rem;
}
.admin-search__clear:hover { color: var(--red); }

/* Locations */
.admin-locations { display: flex; flex-direction: column; gap: .5rem; margin-bottom: .75rem; }
.admin-location-item {
    display: flex; align-items: center; justify-content: space-between;
    padding: .6rem .75rem; background: var(--surface2);
    border: 1px solid var(--border); border-radius: 8px; gap: .75rem;
}
.admin-location-info { display: flex; flex-direction: column; gap: .15rem; }
.admin-location-info strong { font-size: .88rem; color: var(--white); font-weight: 500; }
.admin-location-info span { font-size: .75rem; color: var(--gray2); }
.admin-location-actions { display: flex; gap: .4rem; flex-shrink: 0; }

/* Table row states */
.admin-row--blocked td { opacity: .55; }
.admin-table__name { font-weight: 500; color: var(--white); font-size: .85rem; }
.admin-table__sub { font-size: .72rem; color: var(--gray2); margin-top: .1rem; }
.admin-table__empty { text-align: center; padding: 2rem; color: var(--gray2); font-size: .85rem; }
.admin-table__actions { display: flex; gap: .4rem; flex-wrap: wrap; align-items: center; }
.admin-link-sm { font-size: .72rem; color: var(--teal-light); text-decoration: none; }
.admin-link-sm:hover { text-decoration: underline; }
.admin-qr { font-size: .72rem; color: var(--cyan); font-family: monospace; }

/* Pagination */
.admin-pagination { display: flex; gap: .4rem; margin-top: .75rem; flex-wrap: wrap; }
.admin-pagination__btn {
    padding: .3rem .65rem; border-radius: 6px; font-size: .78rem; font-weight: 500;
    background: var(--surface2); color: var(--gray); border: 1px solid var(--border);
    text-decoration: none; transition: all var(--transition);
}
.admin-pagination__btn:hover { color: var(--white); border-color: var(--border-hover); }
.admin-pagination__btn.active { background: rgba(13,115,119,.2); color: var(--teal-light); border-color: rgba(13,115,119,.4); }

/* Role group separator in users table */
.admin-role-group th {
    background: var(--surface3); color: var(--gray2);
    font-size: .7rem; text-transform: uppercase; letter-spacing: .08em;
    padding: .4rem 1rem; border-bottom: 1px solid var(--border);
}

/* ─── Mini App Layout ────────────────────────────────────────── */
.mini-app {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background: var(--bg);
    max-width: 480px;
    margin: 0 auto;
}

.mini-header {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: 1rem;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 0;
    z-index: 100;
}
.mini-header-back {
    font-size: .88rem;
    color: var(--gray);
    cursor: pointer;
    padding: .35rem;
    text-decoration: none;
}
.mini-header-back:hover { color: var(--white); }
.mini-header h1 {
    font-size: 1.25rem;
    font-weight: 700;
}

.mini-body {
    flex: 1;
    padding: 1rem;
    padding-bottom: 5rem;
    overflow-y: auto;
}

/* Category scroll */
.cat-scroll {
    display: flex;
    gap: .5rem;
    overflow-x: auto;
    padding-bottom: .5rem;
    margin-bottom: 1rem;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.cat-scroll::-webkit-scrollbar { display: none; }

.cat-pill {
    flex-shrink: 0;
    padding: .45rem 1rem;
    border-radius: 100px;
    font-size: .78rem;
    font-weight: 600;
    color: var(--gray);
    background: var(--surface);
    border: 1px solid var(--border);
    cursor: pointer;
    transition: all var(--transition);
    white-space: nowrap;
    font-family: var(--font-b);
}
.cat-pill:hover { border-color: var(--teal); color: var(--white); }
.cat-pill.active {
    background: var(--teal);
    color: var(--white);
    border-color: var(--teal);
}

/* Product Grid */
.product-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .75rem;
}
.product-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r);
    overflow: hidden;
    transition: border-color var(--transition), transform var(--transition);
    position: relative;
}
.product-card:hover { border-color: var(--border-hover); transform: translateY(-2px); }

.product-img {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
}
.product-body {
    padding: .75rem;
}
.product-category {
    font-size: .65rem;
    color: var(--gray2);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: 500;
}
.product-name {
    font-family: var(--font-h);
    font-size: .95rem;
    color: var(--white);
    font-weight: 600;
    margin-top: .15rem;
    letter-spacing: .03em;
}
.product-price {
    font-family: var(--font-h);
    font-size: 1rem;
    color: var(--amber);
    margin-top: .35rem;
    font-weight: 600;
}
.product-status {
    position: absolute;
    top: .6rem; right: .6rem;
}

.product-btn {
    display: block;
    width: 100%;
    padding: .55rem;
    border: none;
    font-family: var(--font-h);
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    cursor: pointer;
    transition: all var(--transition);
    text-align: center;
}
.product-btn.available {
    background: var(--teal);
    color: var(--white);
}
.product-btn.available:hover { background: var(--teal-light); }
.product-btn.busy {
    background: var(--surface2);
    color: var(--gray2);
    cursor: default;
}

/* Coming soon overlay */
.product-card.coming-soon { opacity: .6; pointer-events: none; }
.product-card.coming-soon .coming-overlay {
    position: absolute;
    inset: 0;
    background: rgba(14,17,23,.7);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--r);
    z-index: 2;
}
.coming-tag {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 100px;
    padding: .35rem .8rem;
    font-size: .72rem;
    font-weight: 600;
    color: var(--gray);
    text-transform: uppercase;
    letter-spacing: .08em;
}

/* Tab Bar Override for mini-app */
.mini-app .tab-bar {
    display: flex;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: var(--surface);
    border-top: 1px solid var(--border);
    justify-content: space-around;
    padding: .5rem 0 max(.5rem, env(safe-area-inset-bottom));
    z-index: 100;
    max-width: 480px;
    margin: 0 auto;
    height: auto;
}
.mini-app .tab-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .15rem;
    padding: .25rem .5rem;
    font-size: .62rem;
    color: var(--gray2);
    font-weight: 500;
    cursor: pointer;
    transition: color var(--transition);
    text-decoration: none;
    background: none;
    border: none;
    min-width: auto;
    min-height: auto;
}
.mini-app .tab-item:hover { color: var(--gray); }
.mini-app .tab-item.active { color: var(--teal-light); }
.mini-app .tab-icon { font-size: 1.2rem; }

/* ─── Admin Responsive ───────────────────────────────────────── */
@media (max-width: 768px) {
    .admin-sidebar {
        transform: translateX(-100%);
    }
    .admin-sidebar.open {
        transform: translateX(0);
    }
    .admin-overlay.show { display: block; }
    .admin-burger { display: flex; }
    .admin-main {
        margin-left: 0;
        padding: 4rem 1rem 2rem;
    }
    .kpi-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .admin-table { font-size: .78rem; }
    .admin-table thead th,
    .admin-table tbody td { padding: .5rem .6rem; }
    .op-header-right .op-user { display: none; }
}

/* ─── Utility additions ──────────────────────────────────────── */
.mt-1 { margin-top: .5rem; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; }
.mb-1 { margin-bottom: .5rem; }
.mb-2 { margin-bottom: 1rem; }
.offline-banner.show { display: block; transform: translateY(0); }

/* ═══════════════════════════════════════════════════════════════
   PAGE STYLES (extracted from templates)
   ═══════════════════════════════════════════════════════════════ */

/* ─── Shared: app page shell ─────────────────────────────────── */
.app-shell body { padding-bottom: 80px; }
.page { max-width: 480px; margin: 0 auto; min-height: 100dvh; }
@media(min-width:481px) { .app-shell body { background: #0a0c10; } .page { background: var(--bg); box-shadow: 0 0 60px rgba(0,0,0,.5); } }

/* ─── Shared: app-header ─────────────────────────────────────── */
.app-header { display: flex; align-items: center; justify-content: space-between; padding: 16px; max-width: 480px; margin: 0 auto; }
.app-header__title { font-family: var(--font-h); font-size: 1.125rem; font-weight: 600; text-transform: uppercase; letter-spacing: .03em; }

/* ─── Shared: badge variants ─────────────────────────────────── */
.badge { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 100px; font-size: .688rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.badge--green { background: rgba(46,204,113,.15); color: #2ecc71; }
.badge--amber { background: rgba(232,160,32,.15); color: var(--amber); }
.badge--blue  { background: rgba(52,152,219,.15);  color: #3498db; }
.badge--red   { background: rgba(224,64,64,.15);   color: #e04040; }
.badge-available { background: rgba(46,204,113,.15); color: #2ecc71; display: inline-flex; padding: 3px 10px; border-radius: 100px; font-size: .625rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.badge-busy      { background: rgba(232,160,32,.15); color: var(--amber); display: inline-flex; padding: 3px 10px; border-radius: 100px; font-size: .625rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }

/* ─── Shared: state-empty ────────────────────────────────────── */
.state-empty { text-align: center; padding: 64px 24px; color: var(--gray2); }
.state-empty .state-icon { font-size: 3rem; display: block; margin-bottom: 16px; }
.state-empty .state-title { font-size: 1rem; font-weight: 600; margin-bottom: 8px; color: var(--gray); }

/* ─── Shared: accordion ──────────────────────────────────────── */
.accordion-item { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r2); margin-bottom: 12px; overflow: hidden; }
.accordion-header { display: flex; justify-content: space-between; align-items: center; padding: 18px 24px; cursor: pointer; font-weight: 600; font-size: .9375rem; transition: background .2s ease; user-select: none; }
.accordion-header:hover { background: rgba(255,255,255,.03); }
.accordion-header .chevron { transition: transform .3s ease; color: var(--gray2); font-style: normal; }
.accordion-item.open .accordion-header .chevron { transform: rotate(180deg); }
.accordion-body { padding: 0 24px 20px; color: var(--gray); font-size: .9375rem; line-height: 1.6; display: none; }
.accordion-item.open .accordion-body { display: block; }

/* ─── Shared: hero pattern (витрина) ─────────────────────────── */
.bikes-hero, .contacts-hero, .terms-hero, .workshop-hero {
  background: var(--surface); border-bottom: 1px solid var(--border); padding: 80px 0 48px;
}
.bikes-hero h1, .contacts-hero h1, .terms-hero h1, .workshop-hero h1 {
  font-size: clamp(2rem,5vw,3.5rem); margin-bottom: 12px;
}
.bikes-hero p, .contacts-hero p, .terms-hero p, .workshop-hero p {
  color: var(--gray); max-width: 50ch;
}

/* ─── index.html: hero ───────────────────────────────────────── */
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; z-index: 0; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.hero-bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg,rgba(14,17,23,.92) 0%,rgba(14,17,23,.75) 40%,rgba(13,115,119,.2) 100%); }
.hero-content { position: relative; z-index: 1; padding-top: 120px; padding-bottom: 80px; max-width: 720px; }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; padding: 8px 18px; background: rgba(34,197,94,.1); border: 1px solid rgba(34,197,94,.2); border-radius: 100px; font-size: .8125rem; font-weight: 500; color: var(--green); margin-bottom: 24px; animation: fadeIn .6s ease both; }
.hero-badge .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 8px var(--green); animation: pulse 2s infinite; }
.hero h1 { font-size: clamp(3.5rem,10vw,7rem); margin-bottom: 16px; animation: slideUp .6s ease .1s both; background: linear-gradient(135deg,var(--white) 30%,var(--teal-light)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.hero-subtitle { font-size: clamp(1rem,2.5vw,1.35rem); color: var(--gray); line-height: 1.5; margin-bottom: 36px; animation: slideUp .6s ease .2s both; max-width: 50ch; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 48px; animation: slideUp .6s ease .3s both; }
.hero-stats { display: flex; gap: 48px; animation: slideUp .6s ease .4s both; }
.hero-stat-number { font-family: var(--font-h); font-size: clamp(1.8rem,4vw,2.5rem); font-weight: 700; color: var(--white); line-height: 1.1; }
.hero-stat-label { font-size: .8125rem; color: var(--gray2); margin-top: 4px; }
.hero-glow { position: absolute; bottom: -200px; right: -100px; width: 500px; height: 500px; border-radius: 50%; background: radial-gradient(circle,rgba(13,115,119,.15),transparent 70%); z-index: 0; pointer-events: none; }

/* ─── index.html: steps ──────────────────────────────────────── */
.steps-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; counter-reset: step; }
.step-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r2); padding: 32px 20px 28px; text-align: center; position: relative; transition: all var(--transition); }
.step-card:hover { border-color: var(--border-hover); transform: translateY(-4px); box-shadow: var(--shadow); }
.step-number { width: 48px; height: 48px; border-radius: 50%; background: linear-gradient(135deg,var(--teal),var(--teal-light)); color: var(--white); font-family: var(--font-h); font-size: 1.25rem; font-weight: 700; display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; }
.step-icon { font-size: 2rem; margin-bottom: 12px; }
.step-card h4 { font-size: 1rem; margin-bottom: 8px; }
.step-card p { font-size: .8125rem; margin: 0 auto; }
.step-card:not(:last-child)::after { content: ''; position: absolute; top: 55px; right: -13px; width: 24px; height: 2px; background: var(--border-hover); z-index: 1; }

/* ─── index.html: categories ─────────────────────────────────── */
.category-card { position: relative; overflow: hidden; border-radius: var(--r2); background: var(--surface); border: 1px solid var(--border); transition: all var(--transition); cursor: pointer; }
.category-card:hover { border-color: var(--border-hover); transform: translateY(-4px); box-shadow: var(--shadow); }
.category-card img { width: 100%; aspect-ratio: 16/10; object-fit: cover; transition: transform .4s ease; }
.category-card:hover img { transform: scale(1.05); }
.category-card .card-overlay { position: absolute; inset: 0; background: linear-gradient(to top,rgba(14,17,23,.9) 0%,rgba(14,17,23,.3) 50%,transparent 100%); display: flex; flex-direction: column; justify-content: flex-end; padding: 24px; }
.category-card .card-overlay h3 { font-size: 1.5rem; margin-bottom: 6px; }
.category-card .card-overlay p { font-size: .875rem; color: var(--gray); }
.category-card-soon { border-radius: var(--r2); background: var(--surface); border: 1px dashed var(--border-hover); padding: 32px 20px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; text-align: center; min-height: 200px; opacity: .6; }
.category-card-soon h4 { font-size: 1.1rem; }

/* ─── index.html: CTA ────────────────────────────────────────── */
.cta-section { background: linear-gradient(135deg,var(--surface),var(--surface2)); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.cta-inner { display: flex; align-items: center; gap: 48px; }
.cta-text { flex: 1; }
.cta-text h2 { margin-bottom: 16px; }
.cta-text p { margin-bottom: 24px; }
.cta-visual { flex: 0 0 280px; display: flex; flex-direction: column; align-items: center; gap: 16px; }
.qr-placeholder { width: 180px; height: 180px; background: var(--white); border-radius: var(--r); display: flex; align-items: center; justify-content: center; padding: 20px; }
.qr-placeholder svg { width: 100%; height: 100%; color: var(--bg); }
.store-buttons { display: flex; gap: 12px; }
.store-btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 18px; background: var(--surface3); border: 1px solid var(--border); border-radius: var(--r); color: var(--white); font-size: .8125rem; font-weight: 500; text-decoration: none; transition: all var(--transition); min-height: 44px; }
.store-btn:hover { background: var(--surface); border-color: var(--border-hover); color: var(--white); }
.store-btn svg { width: 20px; height: 20px; }

/* ─── bikes.html ─────────────────────────────────────────────── */
.bikes-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(280px,1fr)); gap: 24px; }
.bike-category-box { position: relative; border-radius: var(--r2); overflow: hidden; border: 1px solid var(--border); display: block; text-decoration: none; transition: all var(--transition); }
.bike-category-box:hover { border-color: var(--border-hover); transform: translateY(-4px); box-shadow: var(--shadow); }
.bike-category-box img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; transition: transform .4s ease; }
.bike-category-box:hover img { transform: scale(1.05); }
.category-info { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(to top,rgba(14,17,23,.9) 0%,transparent 100%); padding: 20px 20px 16px; }
.category-info h3 { font-size: 1.25rem; color: var(--white); margin-bottom: 4px; }
.category-info .category-price { font-size: .875rem; color: var(--amber); font-weight: 600; }
.bike-category-box.coming-soon { opacity: .5; pointer-events: none; }
@media(max-width:768px) { .bikes-grid { grid-template-columns: 1fr 1fr; gap: 16px; } }
@media(max-width:480px)  { .bikes-grid { grid-template-columns: 1fr; gap: 12px; } }

/* ─── contacts.html ──────────────────────────────────────────── */
.contacts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.contacts-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r2); padding: 32px; }
.contacts-card h2 { font-size: 1.5rem; margin-bottom: 24px; }
.contacts-line { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 16px; font-size: .9375rem; }
.contacts-line svg { width: 18px; height: 18px; stroke: var(--teal-light); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; margin-top: 2px; }
.contacts-social { display: flex; gap: 12px; margin-top: 20px; flex-wrap: wrap; }
.contacts-social a { display: inline-flex; align-items: center; gap: 8px; padding: 9px 18px; background: var(--surface2); border: 1px solid var(--border); border-radius: var(--r); color: var(--white); font-size: .875rem; font-weight: 500; text-decoration: none; transition: all var(--transition); }
.contacts-social a:hover { border-color: var(--border-hover); color: var(--white); }
.form-group { margin-bottom: 20px; }
.form-group label { display: block; font-size: .875rem; font-weight: 500; margin-bottom: 8px; color: var(--gray); }
.form-group input, .form-group textarea { width: 100%; background: var(--surface2); border: 1px solid var(--border); border-radius: var(--r); padding: 12px 16px; font-size: .9375rem; color: var(--white); outline: none; font-family: var(--font-b); transition: border var(--transition); }
.form-group input:focus, .form-group textarea:focus { border-color: var(--teal); }
.form-group input::placeholder, .form-group textarea::placeholder { color: var(--gray2); }
.form-group textarea { resize: vertical; min-height: 120px; }
.field-error { font-size: .8125rem; color: #e04040; margin-top: 6px; display: none; }
.alert-success { background: rgba(46,204,113,.1); border: 1px solid rgba(46,204,113,.25); border-radius: var(--r); padding: 12px 16px; color: #2ecc71; margin-bottom: 16px; }
.alert-error   { background: rgba(224,64,64,.1);  border: 1px solid rgba(224,64,64,.25);  border-radius: var(--r); padding: 12px 16px; color: #e04040; margin-bottom: 16px; }
.map-block { margin-top: 32px; border-radius: var(--r2); overflow: hidden; border: 1px solid var(--border); }
.map-block iframe { display: block; filter: grayscale(.3); }
@media(max-width:768px) { .contacts-grid { grid-template-columns: 1fr; gap: 24px; } }

/* ─── workshop.html ──────────────────────────────────────────── */
.services-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); gap: 24px; margin-bottom: 48px; }
.service-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r2); padding: 28px 24px; text-align: center; transition: all var(--transition); }
.service-card:hover { border-color: var(--border-hover); transform: translateY(-4px); box-shadow: var(--shadow); }
.service-card .icon { font-size: 2.5rem; margin-bottom: 16px; }
.service-card h3 { font-size: 1.1rem; margin-bottom: 8px; }
.service-card p { font-size: .875rem; color: var(--gray); }

/* ─── app/catalog.html ───────────────────────────────────────── */
.search-bar { position: relative; margin: 0 16px 16px; }
.search-bar__icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); width: 18px; height: 18px; stroke: var(--gray2); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.search-bar input { padding-left: 42px; border-radius: var(--r); background: var(--surface); height: 46px; font-family: var(--font-b); color: var(--white); border: 1px solid var(--border); width: 100%; outline: none; font-size: .938rem; transition: border .2s ease; }
.search-bar input:focus { border-color: var(--teal); }
.search-bar input::placeholder { color: var(--gray2); }
.filter-pills { display: flex; gap: 8px; overflow-x: auto; padding: 0 16px 16px; max-width: 480px; margin: 0 auto; scrollbar-width: none; }
.filter-pills::-webkit-scrollbar { display: none; }
.filter-pill { white-space: nowrap; padding: 8px 16px; border-radius: 100px; font-size: .813rem; font-weight: 500; background: var(--surface); border: 1px solid var(--border); color: var(--gray); cursor: pointer; transition: all .2s ease; flex-shrink: 0; }
.filter-pill:hover { border-color: var(--teal); color: var(--white); }
.filter-pill.active { background: var(--teal); border-color: var(--teal); color: var(--white); }
.catalog-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; padding: 0 16px; max-width: 480px; margin: 0 auto; }
.catalog-item { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; transition: transform .2s ease, box-shadow .2s ease; text-decoration: none; display: block; color: var(--white); }
.catalog-item:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.3); }
.catalog-item__img { width: 100%; height: 110px; background: var(--surface2); display: flex; align-items: center; justify-content: center; font-size: 2.5rem; position: relative; overflow: hidden; }
.catalog-item__img img { width: 100%; height: 100%; object-fit: cover; }
.catalog-item__badge { position: absolute; top: 8px; right: 8px; }
.catalog-item__body { padding: 12px; }
.catalog-item__name { font-size: .813rem; font-weight: 600; margin-bottom: 4px; line-height: 1.3; }
.catalog-item__price { font-size: .875rem; font-weight: 700; color: var(--amber); }
@keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
.skeleton-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; }
.skeleton-img { width: 100%; height: 110px; background: linear-gradient(90deg,var(--surface2) 25%,#232b3e 50%,var(--surface2) 75%); background-size: 200% 100%; animation: shimmer 1.5s infinite; }
.skeleton-text { height: 14px; margin: 12px; border-radius: 4px; background: linear-gradient(90deg,var(--surface) 25%,var(--surface2) 50%,var(--surface) 75%); background-size: 200% 100%; animation: shimmer 1.5s infinite; }
.skeleton-text--short { width: 60%; }

/* ─── app/home.html ──────────────────────────────────────────── */
.greeting { padding: 20px 16px 8px; max-width: 480px; margin: 0 auto; }
.greeting__name { font-family: var(--font-h); font-size: 1.5rem; font-weight: 600; margin-bottom: 2px; }
.greeting__date { font-size: .813rem; color: var(--gray); }
.banner-verify { margin: 12px 16px; background: rgba(232,160,32,.1); border: 1px solid rgba(232,160,32,.25); border-radius: var(--r); padding: 14px 16px; display: flex; align-items: center; gap: 12px; }
.banner-verify__icon { width: 36px; height: 36px; min-width: 36px; background: rgba(232,160,32,.2); border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.banner-verify__icon svg { width: 18px; height: 18px; stroke: var(--amber); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.banner-verify__content { flex: 1; }
.banner-verify__text { font-size: .813rem; font-weight: 500; color: var(--amber); margin-bottom: 6px; }
.banner-verify__btn { font-size: .75rem; font-weight: 600; color: var(--amber); background: rgba(232,160,32,.15); padding: 5px 14px; border-radius: 100px; border: none; cursor: pointer; transition: background .2s ease; }
.banner-verify__btn:hover { background: rgba(232,160,32,.25); }
.rental-card { margin: 16px; background: var(--surface); border: 1px solid var(--teal); border-radius: var(--r2); padding: 20px; position: relative; overflow: hidden; }
.rental-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg,var(--teal),var(--teal-light)); }
.rental-card__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.rental-card__label { font-size: .75rem; text-transform: uppercase; letter-spacing: .06em; color: var(--gray); font-weight: 500; }
.rental-card__timer { font-family: var(--font-h); font-size: 2.5rem; font-weight: 700; color: var(--teal-light); text-align: center; margin: 8px 0; font-variant-numeric: tabular-nums; }
.rental-card__info { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.rental-card__bike { font-size: .938rem; font-weight: 600; }
.rental-card__cost { font-size: 1.25rem; font-weight: 700; color: var(--amber); font-variant-numeric: tabular-nums; }
.wallet { margin: 0 16px 16px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); padding: 16px; display: flex; align-items: center; justify-content: space-between; }
.wallet__left { display: flex; align-items: center; gap: 12px; }
.wallet__icon { width: 40px; height: 40px; background: rgba(13,115,119,.15); border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.wallet__icon svg { width: 20px; height: 20px; stroke: var(--teal-light); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.wallet__label { font-size: .75rem; color: var(--gray); margin-bottom: 2px; }
.wallet__amount { font-size: 1.25rem; font-weight: 700; font-variant-numeric: tabular-nums; }
.app-section { padding: 0 16px 20px; max-width: 480px; margin: 0 auto; }
.app-section__title { font-family: var(--font-h); font-size: 1rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; margin-bottom: 12px; }
.quick-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.quick-grid__item { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); padding: 18px 16px; display: flex; flex-direction: column; align-items: center; gap: 10px; text-decoration: none; color: var(--white); transition: transform .2s ease, box-shadow .2s ease; }
.quick-grid__item:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.3); }
.quick-grid__icon { width: 44px; height: 44px; border-radius: 12px; display: flex; align-items: center; justify-content: center; }
.quick-grid__icon svg { width: 22px; height: 22px; stroke: var(--white); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.quick-grid__icon--teal  { background: var(--teal); }
.quick-grid__icon--amber { background: #c4861a; }
.quick-grid__icon--blue  { background: #2980b9; }
.quick-grid__icon--green { background: #27ae60; }
.quick-grid__label { font-size: .813rem; font-weight: 600; }
.mini-scroll { display: flex; gap: 12px; overflow-x: auto; padding: 0 16px 8px; max-width: 480px; margin: 0 auto; scrollbar-width: none; }
.mini-scroll::-webkit-scrollbar { display: none; }
.mini-app-card { min-width: 140px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); padding: 16px; text-align: center; flex-shrink: 0; transition: transform .2s ease, box-shadow .2s ease; text-decoration: none; color: var(--white); display: block; }
.mini-app-card:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.3); }
.mini-app-card__icon { font-size: 2rem; margin-bottom: 8px; }
.mini-app-card__name { font-size: .813rem; font-weight: 600; margin-bottom: 4px; }
.mini-app-card__status { font-size: .688rem; color: var(--gray2); }
.mini-app-card__status--active { color: var(--teal-light); }

/* ─── app/history.html ───────────────────────────────────────── */
.tabs { display: flex; gap: 0; margin: 0 16px 16px; background: var(--surface); border-radius: var(--r-sm); border: 1px solid var(--border); overflow: hidden; }
.tabs__item { flex: 1; padding: 10px 12px; text-align: center; font-size: .813rem; font-weight: 500; color: var(--gray); cursor: pointer; transition: all .2s ease; border-right: 1px solid var(--border); }
.tabs__item:last-child { border-right: none; }
.tabs__item:hover { color: var(--white); background: rgba(255,255,255,.03); }
.tabs__item.active { color: var(--teal-light); background: rgba(13,115,119,.1); }
.badge-teal { background: rgba(13,115,119,.2); color: var(--teal-light); }
.history-item { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); padding: 16px; margin-bottom: 10px; transition: transform .2s ease; }
.history-item:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.3); }
.history-item__top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 8px; }
.history-item__name { font-size: .938rem; font-weight: 600; }
.history-item__date { font-size: .75rem; color: var(--gray2); margin-top: 2px; }
.history-item__meta { display: flex; gap: 16px; align-items: center; font-size: .813rem; color: var(--gray); }
.history-item__cost { font-weight: 700; color: var(--white); }
.pagination { display: flex; justify-content: center; align-items: center; gap: 8px; padding: 20px 16px; }
.pagination__btn { width: 36px; height: 36px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: .813rem; font-weight: 600; background: var(--surface); border: 1px solid var(--border); color: var(--gray); cursor: pointer; transition: all .2s ease; text-decoration: none; }
.pagination__btn:hover { border-color: var(--teal); color: var(--white); }
.pagination__btn.active { background: var(--teal); border-color: var(--teal); color: var(--white); }

/* ─── app/profile.html ───────────────────────────────────────── */
.profile-hero { text-align: center; padding: 28px 16px 20px; max-width: 480px; margin: 0 auto; }
.profile-avatar { width: 80px; height: 80px; border-radius: 50%; background: linear-gradient(135deg,var(--teal),var(--teal-light)); margin: 0 auto 12px; display: flex; align-items: center; justify-content: center; font-family: var(--font-h); font-size: 2rem; font-weight: 700; color: var(--white); }

/* Новая шапка профиля */
.profile-hero-card{
  text-align:center;
  padding:28px 16px 20px;
  max-width:480px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
}
.profile-avatar-wrap{cursor:default;}
.profile-avatar-circle{
  width:120px;
  height:120px;
  border-radius:14px;
  border:3px solid var(--teal);
  overflow:hidden;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--surface2);
  margin-bottom:4px;
}
.profile-avatar-img{width:100%;height:100%;object-fit:cover;}
.profile-avatar-initials{
  font-family:'Oswald',sans-serif;
  font-size:2.5rem;
  font-weight:700;
  color:var(--white);
  user-select:none;
}
.profile-avatar-upload{
  position:absolute;
  bottom:4px;
  right:4px;
  width:28px;
  height:28px;
  border-radius:8px;
  background:var(--teal);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  opacity:0.8;
  transition:opacity 0.2s;
}
.profile-avatar-upload:hover{opacity:1;}
.profile-hero-name{
  font-family:var(--font-h);
  font-size:1.25rem;
  font-weight:600;
  color:var(--white);
  line-height:1.2;
}
.profile-hero-id{
  font-size:1.1rem;
  color:var(--white);
  font-family:var(--font-h);
}
.profile-hero-badge{
  display:inline-flex;
  align-items:center;
  flex-direction:column;
  align-items:center;
  gap:4px;
}
.profile-unverified-badge{
  background:rgba(245,158,11,.15);
  color:#f59e0b;
  border:1px solid rgba(245,158,11,.3);
  border-radius:8px;
  padding:4px 12px;
  font-size:.8rem;
  font-weight:600;
}
.profile-verify-link{
  font-size:.75rem;
  color:var(--teal-light);
  text-decoration:none;
}
.profile-verify-link:hover{text-decoration:underline;}
.profile-hero-badge--warning{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  background:rgba(245,158,11,.15);
  color:#f59e0b;
  border:1px solid rgba(245,158,11,.3);
  border-radius:20px;
  padding:.35rem .9rem;
  font-size:.8rem;
  font-weight:600;
  text-decoration:none;
  transition:background .2s;
}
.profile-hero-badge--warning:hover{background:rgba(245,158,11,.25);}
.profile-hero-meta{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  justify-content:center;
  font-size:.88rem;
  color:var(--gray2);
  margin-top:4px;
}
.profile-meta-clock{color:var(--white);font-weight:600;}
.profile-meta-sep{color:var(--gray2);opacity:.5;}
.profile-meta-weather{
  display:flex;
  align-items:center;
  gap:4px;
  text-decoration:none;
  color:var(--gray2);
}
.profile-name { font-family: var(--font-h); font-size: 1.375rem; font-weight: 600; margin-bottom: 4px; }
.profile-phone { font-size: .813rem; color: var(--gray); }
.profile-section { padding: 0 16px 20px; max-width: 480px; margin: 0 auto; }
.profile-section__title { font-family: var(--font-h); font-size: .875rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; color: var(--gray); margin-bottom: 12px; }
.profile-item { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 14px 16px; display: flex; align-items: center; gap: 12px; margin-bottom: 8px; transition: transform .2s ease; }
.profile-item:hover { transform: translateY(-1px); }
.profile-item__icon { width: 36px; height: 36px; min-width: 36px; border-radius: 8px; display: flex; align-items: center; justify-content: center; }
.profile-item__icon svg { width: 18px; height: 18px; stroke: var(--white); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.profile-item__content { flex: 1; }
.profile-item__name { font-size: .875rem; font-weight: 600; }
.profile-item__desc { font-size: .75rem; color: var(--gray); margin-top: 2px; }
.qr-block { text-align: center; padding: 20px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); margin-bottom: 8px; }
.qr-block__img { width: 150px; height: 150px; margin: 0 auto 12px; border-radius: 8px; background: #fff; padding: 8px; }
.qr-block__img img { width: 100%; height: 100%; border-radius: 4px; }
.qr-block__text { font-size: .813rem; color: var(--gray); }
.doc-link { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm); margin-bottom: 8px; color: var(--white); text-decoration: none; font-size: .875rem; font-weight: 500; transition: transform .2s ease; }
.doc-link:hover { transform: translateY(-1px); color: var(--white); }
.doc-link svg { width: 16px; height: 16px; stroke: var(--gray2); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.btn-amber-solid { display: inline-flex; align-items: center; justify-content: center; padding: 8px 16px; border-radius: var(--r-sm); font-size: .75rem; font-weight: 600; background: var(--amber); color: #1a1a1a; border: none; cursor: pointer; transition: all .2s ease; }
.btn-amber-solid:hover { background: #f0b84a; }
.btn-ghost-inline { display: inline-flex; align-items: center; justify-content: center; padding: 8px 16px; border-radius: var(--r-sm); font-size: .75rem; font-weight: 600; background: transparent; border: 1px solid var(--border); color: var(--white); cursor: pointer; transition: all .2s ease; }
.btn-ghost-inline:hover { border-color: var(--gray); }
.btn-ghost-red-full { display: flex; align-items: center; justify-content: center; width: 100%; padding: 12px 24px; border-radius: var(--r-sm); font-size: .875rem; font-weight: 600; background: transparent; border: 1px solid rgba(224,64,64,.3); color: #e04040; text-decoration: none; transition: all .2s ease; }
.btn-ghost-red-full:hover { border-color: #e04040; background: rgba(224,64,64,.08); color: #e04040; }
.btn-ghost-full { display: flex; align-items: center; justify-content: center; width: 100%; padding: 12px 24px; border-radius: var(--r-sm); font-size: .875rem; font-weight: 600; background: transparent; border: 1px solid var(--border); color: var(--white); text-decoration: none; transition: all .2s ease; }
.btn-ghost-full:hover { border-color: var(--gray); }

/* ─── rent_active.html ───────────────────────────────────────── */
.rent-timer-block { text-align: center; padding: 40px 16px 20px; }
.rent-timer { font-family: var(--font-h); font-size: 5rem; font-weight: 700; color: var(--teal-light); font-variant-numeric: tabular-nums; line-height: 1; animation: timerPulse 2s ease-in-out infinite; }
@keyframes timerPulse { 0%,100% { opacity: 1; } 50% { opacity: .8; } }
.rent-cost { font-size: 2rem; font-weight: 700; color: var(--amber); margin-top: 8px; font-variant-numeric: tabular-nums; }
.rent-cost-label { font-size: .813rem; color: var(--gray); margin-top: 4px; }
.bike-card { margin: 16px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r2); overflow: hidden; }
.bike-card__img { width: 100%; height: 180px; object-fit: cover; background: var(--surface2); display: block; }
.bike-card__body { padding: 16px; }
.bike-card__name { font-family: var(--font-h); font-size: 1.125rem; font-weight: 600; margin-bottom: 6px; }
.bike-card__location { font-size: .813rem; color: var(--gray); display: flex; align-items: center; gap: 6px; }
.bike-card__location svg { width: 14px; height: 14px; stroke: var(--teal-light); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.offline-rent { margin: 0 16px 16px; background: rgba(232,160,32,.1); border: 1px solid rgba(232,160,32,.25); border-radius: var(--r-sm); padding: 12px 16px; font-size: .813rem; color: var(--amber); display: none; align-items: center; gap: 8px; }
.offline-rent svg { width: 16px; height: 16px; stroke: var(--amber); fill: none; stroke-width: 2; min-width: 16px; }
.offline-rent.visible { display: flex; }
.bottom-sheet-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 2000; opacity: 0; visibility: hidden; transition: opacity .3s, visibility .3s; }
.bottom-sheet-overlay.open { opacity: 1; visibility: visible; }
.bottom-sheet { position: fixed; bottom: 0; left: 0; right: 0; z-index: 2001; background: var(--surface); border-top-left-radius: 20px; border-top-right-radius: 20px; padding: 24px 20px; padding-bottom: calc(24px + env(safe-area-inset-bottom,0px)); max-width: 480px; margin: 0 auto; transform: translateY(100%); transition: transform .35s cubic-bezier(.32,.72,0,1); }
.bottom-sheet-overlay.open .bottom-sheet { transform: translateY(0); }
.bottom-sheet__handle { width: 40px; height: 4px; background: var(--border); border-radius: 2px; margin: 0 auto 20px; }
.bottom-sheet__title { font-family: var(--font-h); font-size: 1.25rem; font-weight: 600; text-align: center; margin-bottom: 8px; }
.bottom-sheet__cost { font-size: 2rem; font-weight: 700; color: var(--amber); text-align: center; margin-bottom: 20px; font-variant-numeric: tabular-nums; }
.bottom-sheet__actions { display: flex; flex-direction: column; gap: 10px; }
.live-dot { width: 8px; height: 8px; background: #2ecc71; border-radius: 50%; animation: timerPulse 2s ease-in-out infinite; }
.btn-red-full { display: flex; align-items: center; justify-content: center; width: 100%; height: 56px; border-radius: var(--r); font-family: var(--font-h); font-size: 1rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; background: #e04040; color: var(--white); border: none; cursor: pointer; transition: all .2s ease; }
.btn-red-full:hover { background: #c03030; }
.btn-ghost-full-sm { display: flex; align-items: center; justify-content: center; width: 100%; height: 48px; border-radius: var(--r-sm); font-size: .875rem; font-weight: 600; background: transparent; border: 1px solid var(--border); color: var(--white); cursor: pointer; transition: all .2s ease; font-family: var(--font-b); }
.btn-ghost-full-sm:hover { border-color: var(--gray); }

/* ─── app/qr_scan.html ───────────────────────────────────────── */
.qr-scanner { position: relative; min-height: 100dvh; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 0; overflow: hidden; }
.qr-scanner__bg { position: absolute; inset: 0; background: var(--bg); }
.qr-scanner__frame { position: relative; width: 260px; height: 260px; z-index: 1; }
.qr-scanner__corner { position: absolute; width: 36px; height: 36px; border: 3px solid #2ecc71; }
.qr-scanner__corner--tl { top: 0; left: 0; border-right: none; border-bottom: none; border-radius: 4px 0 0 0; }
.qr-scanner__corner--tr { top: 0; right: 0; border-left: none; border-bottom: none; border-radius: 0 4px 0 0; }
.qr-scanner__corner--bl { bottom: 0; left: 0; border-right: none; border-top: none; border-radius: 0 0 0 4px; }
.qr-scanner__corner--br { bottom: 0; right: 0; border-left: none; border-top: none; border-radius: 0 0 4px 0; }
.qr-scanner__line { position: absolute; left: 10px; right: 10px; height: 2px; background: #2ecc71; box-shadow: 0 0 12px rgba(46,204,113,.6); animation: scanLine 2s ease-in-out infinite; border-radius: 1px; }
@keyframes scanLine { 0%,100% { top: 10px; } 50% { top: calc(100% - 10px); } }
.qr-scanner__text { position: relative; z-index: 1; text-align: center; font-size: .938rem; color: var(--gray); margin-top: 32px; padding: 0 24px; }
.qr-scanner__actions { position: relative; z-index: 1; margin-top: 32px; display: flex; flex-direction: column; gap: 16px; width: 100%; max-width: 300px; padding: 0 24px; }
.qr-scanner__manual { display: flex; gap: 8px; }
.qr-scanner__manual input { flex: 1; text-align: center; font-size: 1rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; padding: 12px 16px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm); color: var(--white); outline: none; font-family: var(--font-b); transition: border .2s ease; }
.qr-scanner__manual input:focus { border-color: var(--teal); }
.qr-scanner__manual input::placeholder { color: var(--gray2); }
.qr-scanner__offline { position: fixed; inset: 0; background: rgba(14,17,23,.92); z-index: 100; display: none; flex-direction: column; align-items: center; justify-content: center; gap: 12px; }
.qr-scanner__offline.visible { display: flex; }
.qr-scanner__offline svg { width: 48px; height: 48px; stroke: var(--gray); fill: none; stroke-width: 1.5; }
.qr-scanner__offline-text { font-size: 1rem; color: var(--gray); font-weight: 500; }
.btn-teal-full { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 12px 24px; border-radius: var(--r-sm); font-size: .875rem; font-weight: 600; background: var(--teal); color: var(--white); border: none; cursor: pointer; transition: all .2s ease; font-family: var(--font-b); }
.btn-teal-full:hover { background: var(--teal-light); }
.btn-teal-sm { display: inline-flex; align-items: center; justify-content: center; padding: 12px 20px; border-radius: var(--r-sm); font-size: .875rem; font-weight: 600; background: var(--teal); color: var(--white); border: none; cursor: pointer; transition: all .2s ease; font-family: var(--font-b); }
.btn-teal-sm:hover { background: var(--teal-light); }
.header-back { display: flex; align-items: center; gap: 8px; color: var(--white); font-size: .938rem; font-weight: 500; text-decoration: none; }
.header-back svg { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

/* ─── mini/bikes/index.html ──────────────────────────────────── */
.mini-app { max-width: 480px; margin: 0 auto; min-height: 100dvh; }
.mini-header { display: flex; align-items: center; gap: 12px; padding: 16px; border-bottom: 1px solid var(--border); }
.mini-header a { color: var(--white); text-decoration: none; font-size: 1.25rem; line-height: 1; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; border-radius: 8px; background: var(--surface); border: 1px solid var(--border); }
.mini-header h1 { font-family: var(--font-h); font-size: 1.125rem; font-weight: 600; text-transform: uppercase; letter-spacing: .03em; }
.mini-body { padding: 16px; }
.cat-scroll { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 16px; scrollbar-width: none; margin: -4px 0 4px; }
.cat-scroll::-webkit-scrollbar { display: none; }
.cat-pill { white-space: nowrap; padding: 7px 16px; border-radius: 100px; font-size: .813rem; font-weight: 500; background: var(--surface); border: 1px solid var(--border); color: var(--gray); cursor: pointer; transition: all .2s ease; flex-shrink: 0; }
.cat-pill:hover { border-color: var(--teal); color: var(--white); }
.cat-pill.active { background: var(--teal); border-color: var(--teal); color: var(--white); }
.product-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.product-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; position: relative; transition: transform .2s ease; }
.product-card:hover { transform: translateY(-2px); }
.product-img { width: 100%; height: 110px; object-fit: cover; display: block; background: var(--surface2); }
.product-status { position: absolute; top: 8px; right: 8px; }
.product-body { padding: 10px 12px 8px; }
.product-category { font-size: .688rem; text-transform: uppercase; letter-spacing: .05em; color: var(--gray2); margin-bottom: 2px; }
.product-name { font-size: .813rem; font-weight: 600; margin-bottom: 4px; line-height: 1.3; }
.product-price { font-size: .875rem; font-weight: 700; color: var(--amber); }
.product-btn { display: block; width: 100%; padding: 10px; text-align: center; font-size: .813rem; font-weight: 600; border: none; cursor: pointer; font-family: var(--font-b); transition: all .2s ease; }
.product-btn.available { background: var(--teal); color: var(--white); }
.product-btn.available:hover { background: var(--teal-light); }
.product-btn.busy { background: var(--surface2); color: var(--gray2); cursor: default; }
.coming-soon { position: relative; }
.coming-overlay { position: absolute; inset: 0; background: rgba(14,17,23,.7); display: flex; align-items: center; justify-content: center; z-index: 1; }
.coming-tag { background: var(--surface); border: 1px solid var(--border); border-radius: 100px; padding: 6px 16px; font-size: .75rem; font-weight: 600; color: var(--gray); }
@media(min-width:481px) { .mini-app { background: var(--bg); box-shadow: 0 0 60px rgba(0,0,0,.5); } }

/* ─── operator/scan.html ─────────────────────────────────────── */
.scanner-container { max-width: 480px; margin: 0 auto; }
.scanner-viewport { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 32px 20px; gap: 20px; text-align: center; }
.scanner-frame { position: relative; width: 240px; height: 240px; margin: 0 auto; }
.scanner-frame .corner-tl, .scanner-frame .corner-tr, .scanner-frame .corner-bl, .scanner-frame .corner-br { position: absolute; width: 32px; height: 32px; border: 3px solid #2ecc71; }
.scanner-frame .corner-tl { top: 0; left: 0; border-right: none; border-bottom: none; border-radius: 4px 0 0 0; }
.scanner-frame .corner-tr { top: 0; right: 0; border-left: none; border-bottom: none; border-radius: 0 4px 0 0; }
.scanner-frame .corner-bl { bottom: 0; left: 0; border-right: none; border-top: none; border-radius: 0 0 0 4px; }
.scanner-frame .corner-br { bottom: 0; right: 0; border-left: none; border-top: none; border-radius: 0 0 4px 0; }
.scan-line { position: absolute; left: 8px; right: 8px; height: 2px; background: #2ecc71; box-shadow: 0 0 10px rgba(46,204,113,.6); animation: scanLine 2s ease-in-out infinite; }
.scanner-hint { font-size: .875rem; color: var(--gray); max-width: 280px; }
.loader { display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 48px 24px; }
.loader-spinner { width: 48px; height: 48px; border: 3px solid var(--border); border-top-color: var(--teal); border-radius: 50%; animation: spin 0.8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.loader-text { font-size: .875rem; color: var(--gray); }
.client-profile { padding: 24px 20px; text-align: center; }
.client-avatar { width: 72px; height: 72px; border-radius: 50%; background: linear-gradient(135deg,var(--teal),var(--teal-light)); margin: 0 auto 12px; display: flex; align-items: center; justify-content: center; font-family: var(--font-h); font-size: 1.75rem; font-weight: 700; color: var(--white); }
.client-name { font-family: var(--font-h); font-size: 1.25rem; font-weight: 600; margin-bottom: 4px; }
.client-phone { font-size: .875rem; color: var(--gray); margin-bottom: 12px; }
.client-status { display: inline-flex; align-items: center; padding: 4px 14px; border-radius: 100px; font-size: .75rem; font-weight: 600; }
.client-status.verified   { background: rgba(46,204,113,.15); color: #2ecc71; }
.client-status.unverified { background: rgba(232,160,32,.15); color: var(--amber); }
.client-rental-info { background: var(--surface2); border-radius: var(--r); padding: 14px 16px; margin: 16px 0; text-align: left; }
.client-rental-label { font-size: .75rem; text-transform: uppercase; letter-spacing: .05em; color: var(--gray); margin-bottom: 4px; }
.client-rental-detail { font-size: .938rem; font-weight: 600; }
.client-actions { display: flex; flex-direction: column; gap: 10px; margin-top: 20px; }
.hidden { display: none !important; }
.btn-green { background: #27ae60; color: #fff; }
.btn-green:hover { background: #229954; }

/* ─── index.html responsive ──────────────────────────────────── */
@media(max-width:768px) {
  .hero-content { padding-top: 120px; padding-bottom: 48px; }
  .hero-stats { gap: 32px; }
  .steps-grid { grid-template-columns: 1fr 1fr; gap: 16px; }
  .step-card::after { display: none !important; }
  .cta-inner { flex-direction: column; text-align: center; }
  .cta-text p { margin-left: auto; margin-right: auto; }
  .cta-visual { flex: none; width: 100%; }
  .hero-actions { flex-direction: column; }
  .hero-actions .btn { width: 100%; }
}
@media(max-width:480px) {
  .steps-grid { grid-template-columns: 1fr; }
  .hero-stats { flex-direction: column; gap: 16px; }
  .store-buttons { flex-direction: column; width: 100%; }
  .store-btn { justify-content: center; }
}
@media(min-width:769px) and (max-width:1024px) {
  .steps-grid { grid-template-columns: repeat(2,1fr); }
  .step-card::after { display: none !important; }
}

/* ─── Footer messengers (Фаза 1) ─────────────────────────────── */
.footer-messengers{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}
.footer-msg-icon{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;background:var(--clr,var(--surface3));color:#fff;transition:opacity var(--transition);flex-shrink:0}
.footer-msg-icon:hover{opacity:.85}
.footer-msg-icon svg{display:block}
.footer-msg-icon--disabled{opacity:.38;cursor:default;pointer-events:none}
.footer-chat-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:8px;background:var(--teal);color:#fff;border:none;cursor:pointer;font-size:.875rem;font-family:var(--font-b);transition:background var(--transition);margin-top:6px;text-decoration:none}
.footer-chat-btn:hover{background:var(--teal-light)}

/* ─── Contacts messenger cards (Фаза 5) ─────────────────────── */
.contacts-messengers{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.contacts-msg-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 10px;border-radius:12px;background:color-mix(in srgb,var(--msg-color,var(--surface3)) 15%,var(--surface));border:1px solid color-mix(in srgb,var(--msg-color,var(--surface3)) 30%,transparent);text-decoration:none;color:var(--text);transition:transform var(--transition),border-color var(--transition);min-width:72px;text-align:center;cursor:pointer}
.contacts-msg-card:hover{transform:translateY(-2px);border-color:var(--msg-color,var(--border))}
.contacts-msg-card--disabled{opacity:.45;cursor:default;pointer-events:none}
.contacts-msg-card__icon{width:44px;height:44px;border-radius:10px;background:var(--msg-color,var(--surface3));display:flex;align-items:center;justify-content:center}
.contacts-msg-card__label{font-size:.75rem;color:var(--gray);line-height:1.2}
.contacts-msg-card__label small{display:block;font-size:.65rem;color:var(--gray2)}

/* ─── KPI card links (Фаза 9) ────────────────────────────────── */
.kpi-card--link{display:block;text-decoration:none;cursor:pointer;transition:border-color var(--transition),transform var(--transition)}
.kpi-card--link:hover{border-color:var(--teal-light);transform:translateY(-2px)}
.kpi-card--link .kpi-label,.kpi-card--link .kpi-value,.kpi-card--link .kpi-delta{color:inherit}

/* ─── Dashboard accordion (Фаза 12) ─────────────────────────── */
.admin-accordion__toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:0;cursor:pointer;color:var(--white);font-family:var(--font-b);font-size:1rem;font-weight:600}
.admin-accordion__toggle svg{transition:transform .25s ease;flex-shrink:0}
.admin-accordion__toggle.open svg{transform:rotate(180deg)}
.admin-accordion__body{overflow:hidden;transition:max-height .35s ease}

/* ─── Repair expand accordion (Фаза 19) ─────────────────────── */
.repair-accordion__toggle{background:none;border:none;cursor:pointer;color:var(--teal-light);font-size:.8rem;padding:0;font-family:var(--font-b);display:inline-flex;align-items:center;gap:4px;margin-top:4px}
.repair-accordion__toggle:hover{color:var(--cyan)}
.repair-accordion__body{display:none;background:var(--surface2);border-radius:8px;padding:10px 12px;margin-top:6px;font-size:.8rem;color:var(--gray);line-height:1.6}
.repair-accordion__body.open{display:block}
.repair-accordion__body p{margin-bottom:4px}
.repair-accordion__body strong{color:var(--text)}

/* ─── About modal (Фаза 2) ───────────────────────────────────── */
#aboutModal{border:1px solid var(--border);border-radius:var(--r2);background:var(--surface);color:var(--text);padding:0;max-width:560px;width:calc(100% - 32px)}
#aboutModal::backdrop{background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}
.about-modal-inner{padding:32px}
.about-modal-title{font-family:var(--font-h);font-size:1.6rem;font-weight:700;background:linear-gradient(90deg,var(--teal-light),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}
.about-modal-sub{color:var(--gray2);font-size:.875rem;margin-bottom:20px}
.about-modal-section{margin-bottom:16px}
.about-modal-section h3{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gray2);margin-bottom:8px;font-weight:600}
.about-modal-tags{display:flex;flex-wrap:wrap;gap:8px}
.about-modal-tag{padding:4px 12px;border-radius:20px;background:var(--surface3);border:1px solid var(--border);font-size:.8rem;color:var(--text)}
.about-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--gray2);cursor:pointer;font-size:1.2rem;line-height:1;padding:4px;border-radius:4px}
.about-modal-close:hover{color:var(--white)}
#aboutModal form{display:contents}

@media(max-width:600px){
  .footer-messengers{gap:8px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .contacts-messengers{gap:8px}
}

/* ===== ФАЗА 3 — Аватарка пользователя в шапке ===== */
.user-avatar-btn{width:36px;height:36px;border-radius:50%;border:2px solid rgba(255,255,255,.15);color:#fff;font-size:.8rem;font-weight:700;font-family:'Oswald',sans-serif;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:box-shadow .2s,transform .15s;position:relative}
.user-avatar-btn:hover{box-shadow:0 0 0 3px rgba(13,115,119,.4);transform:scale(1.08)}
.nav-btn--login{display:inline-flex;align-items:center;gap:.3rem;padding:6px 14px;border-radius:8px;border:1px solid var(--border);color:var(--gray);font-size:.875rem;transition:color var(--transition),border-color var(--transition)}
.nav-btn--login:hover{color:var(--white);border-color:var(--teal-light)}
.nav-btn__avatar-placeholder{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--surface2)}

/* ===== ФАЗА 4 — Popup-меню пользователя ===== */
.user-popup{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 16px 48px rgba(0,0,0,.5);backdrop-filter:blur(12px);z-index:1000;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .15s,transform .15s,visibility .15s;padding:.5rem 0}
.user-popup--open{opacity:1;visibility:visible;transform:translateY(0)}
.user-popup__header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem}
.user-popup__avatar{width:36px;height:36px;border-radius:50%;color:#fff;font-size:.8rem;font-weight:700;font-family:'Oswald',sans-serif;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.user-popup__name{font-size:.9rem;font-weight:600;color:var(--text)}
.user-popup__role{font-size:.75rem;color:var(--teal-light)}
.user-popup__divider{height:1px;background:var(--border);margin:.3rem 0}
.user-popup__item{display:block;padding:.55rem 1rem;color:var(--text);text-decoration:none;font-size:.85rem;transition:background .12s}
.user-popup__item:hover{background:var(--surface2)}
.user-popup__item--danger{color:#ef476f}
.user-popup__item--danger:hover{background:rgba(239,71,111,.1)}

/* ===== ФАЗА 8 — Топбар: дата+часы+погода ===== */
.admin-topbar__datetime{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.admin-topbar__clock{font-family:'Oswald',sans-serif;font-size:1.4rem;font-weight:600;color:var(--text);letter-spacing:.02em}
.admin-topbar__date{font-family:'Oswald',sans-serif;font-size:1.05rem;color:var(--teal-light);font-weight:400}
.admin-topbar__weather{font-size:.95rem;color:var(--gray2)}
.admin-topbar__title{display:flex;align-items:center;line-height:1}
.admin-topbar__title h1,.admin-topbar__title .admin-h1{margin:0;line-height:1;font-size:1.5rem;font-family:'Oswald',sans-serif;font-weight:600;color:var(--text)}
@media(max-width:600px){
  .admin-topbar__datetime{gap:.5rem}
  .admin-topbar__clock{font-size:1.1rem}
  .admin-topbar__date{font-size:.85rem}
  .admin-topbar__title h1,.admin-topbar__title .admin-h1{font-size:1.1rem}
}

/* ===== Мои смены — панель управления ===== */
.shift-dashboard{
  display:grid;
  grid-template-columns:1fr auto;
  gap:1rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:14px;
  padding:1.25rem 1.5rem;
  align-items:start;
}
.shift-dashboard__control{display:flex;flex-direction:column;gap:.85rem}
.shift-status-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.shift-started{font-size:.83rem;color:var(--gray2)}
.shift-actions{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.shift-month-form{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-top:.25rem}
.shift-month-input{background:var(--surface2,rgba(255,255,255,.05));border:1px solid var(--border);border-radius:8px;color:var(--text);padding:.3rem .6rem;font-size:.88rem;font-family:inherit}
.shift-month-label{font-family:'Oswald',sans-serif;font-size:1rem;color:var(--teal-light);white-space:nowrap}
.shift-dashboard__metrics{display:flex;flex-direction:column;gap:.6rem;min-width:150px}
.shift-dashboard__metrics .revenue-metric-card{min-width:0;padding:.7rem 1rem}
.shift-dashboard__metrics .revenue-metric-card__value{font-size:1.3rem}
@media(max-width:700px){
  .shift-dashboard{grid-template-columns:1fr}
  .shift-dashboard__metrics{flex-direction:row;flex-wrap:wrap}
  .shift-dashboard__metrics .revenue-metric-card{flex:1;min-width:120px}
}

/* shift-control-panel — новый layout для Мои смены */
.shift-control-panel{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:14px;
  padding:1.25rem 1.5rem;
  display:flex;
  flex-direction:column;
  gap:1rem;
  margin-bottom:1.5rem;
}
.shift-control-panel__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
  flex-wrap:wrap;
}
.shift-metrics-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.shift-metric-card{
  background:var(--surface2,rgba(255,255,255,.04));
  border:1px solid var(--border);
  border-radius:10px;
  padding:.875rem 1rem;
  text-align:center;
}
.shift-metric-card__value{
  font-family:'Oswald',sans-serif;
  font-size:1.5rem;
  font-weight:600;
  color:var(--white);
  line-height:1.1;
}
.shift-metric-card__label{
  font-size:.75rem;
  color:var(--gray2);
  margin-top:.3rem;
}
@media(max-width:600px){
  .shift-metrics-grid{grid-template-columns:1fr}
  .shift-control-panel__row{flex-direction:column;align-items:flex-start}
}

/* ===== ФАЗА 11 — Блок «Сейчас» ===== */
.online-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin:1.5rem 0}
.online-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1rem;text-align:center}
.online-stat-card__value{font-family:'Oswald',sans-serif;font-size:1.6rem;font-weight:600;color:var(--teal-light)}
.online-stat-card__label{font-size:.8rem;color:var(--gray2);margin-top:.3rem}

/* ===== ФАЗА 13 — Поиск ===== */
.admin-search{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem}
.admin-btn--sm{font-size:.78rem;padding:.3rem .75rem;height:auto}
.admin-btn--gray{background:var(--surface3);color:var(--gray);border:1px solid var(--border)}
.admin-btn--gray:hover{background:var(--surface2);color:var(--white)}

/* ===== ФАЗА 20 — Атрибуция механика ===== */
.mechanic-attribution{border-left:3px solid var(--teal,#0d7377)}

/* ===== ФАЗА 10 — Аналитика выручки ===== */
.revenue-range-btn{padding:.4rem 1rem;border:1px solid var(--border,#23272f);border-radius:8px;background:var(--surface,#181c24);color:var(--gray2,#888);cursor:pointer;font-size:.85rem;transition:all .15s}
.revenue-range-btn:hover{border-color:var(--teal,#0d7377);color:var(--text,#e6e6e6)}
.revenue-range-btn--active{background:var(--teal,#0d7377);border-color:var(--teal,#0d7377);color:#fff}
.revenue-metric-card{background:var(--surface,#181c24);border:1px solid var(--border,#23272f);border-radius:10px;padding:1rem;text-align:center}
.revenue-metric-card__value{font-family:'Oswald',sans-serif;font-size:1.5rem;font-weight:600;color:var(--teal-light,#14cdad)}
.revenue-metric-card__label{font-size:.8rem;color:var(--gray2,#888);margin-top:.3rem}
.revenue-heatmap{display:flex;flex-direction:column;gap:2px;min-width:700px}
.heatmap-row{display:flex;gap:2px}
.heatmap-cell{width:28px;height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:rgba(255,255,255,.7);flex-shrink:0}
.heatmap-cell--label{width:28px;font-size:.7rem;color:var(--gray2,#888);font-weight:600;background:none}
.heatmap-cell--header{font-size:.65rem;color:var(--gray2,#888);background:none}
@media(max-width:768px){.heatmap-cell{width:22px;height:22px;font-size:.55rem}.heatmap-cell--label{width:22px}}

/* ===== ФАЗА 7 — Сайдбар: шапка + drag-and-drop ===== */

/* Шапка сайдбара */
.sidebar-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1rem .75rem;border-bottom:1px solid var(--border,#23272f);margin-bottom:.5rem;flex-shrink:0}
.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:var(--teal,#0d7377);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-size:1rem;font-weight:600;flex-shrink:0}
.sidebar-user-info{display:flex;flex-direction:column;gap:.1rem;min-width:0;flex:1}
.sidebar-user-name{font-size:.88rem;font-weight:600;color:var(--text,#e6e6e6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-role{font-size:.72rem;color:var(--gray2,#888);text-transform:uppercase;letter-spacing:.3px}
.sidebar-logout-btn{color:var(--gray2,#888);padding:.35rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s;flex-shrink:0}
.sidebar-logout-btn:hover{color:#ef4444;background:rgba(239,68,68,.1)}

/* Навигация — список (сбрасываем браузерные стили <ul>) */
.sidebar-nav-list{list-style:none;padding:0;margin:0}

/* Drag-and-drop */
.nav-draggable{cursor:grab;user-select:none;-webkit-user-select:none;transition:opacity .15s,box-shadow .15s}
.nav-draggable:active{cursor:grabbing}
.nav-dragging{opacity:.5;box-shadow:0 4px 16px rgba(0,0,0,.3);z-index:100;position:relative;background:var(--surface2,#1e222a);border-radius:8px}
.nav-drag-ghost{position:fixed;z-index:10000;pointer-events:none;opacity:.85;transform:scale(1.05);background:var(--surface2,#1e222a);border:1px solid var(--teal,#0d7377);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.4);padding:.3rem .5rem;list-style:none}

@media(max-width:768px){
  .sidebar-header{padding:.75rem .85rem .6rem}
  .sidebar-avatar{width:30px;height:30px;font-size:.85rem}
  .sidebar-user-name{font-size:.82rem}
  .nav-draggable{min-height:44px;display:flex;align-items:center}
  .nav-draggable .admin-nav-item{width:100%}
}

/* ===== ФАЗА 14 — Смены: форма ===== */
.admin-label{display:block;font-size:.8rem;color:var(--gray2);margin-bottom:.3rem;font-weight:500}
.admin-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:.45rem .7rem;font-size:.9rem;font-family:'Inter',sans-serif;box-sizing:border-box}
.admin-input:focus{outline:none;border-color:var(--teal)}

/* ===== ФАЗА 18 — Табы аналитики ===== */
.revenue-tab{background:none;border:none;border-bottom:2px solid transparent;padding:.6rem 1.25rem;cursor:pointer;font-size:.9rem;color:var(--gray2);font-family:'Inter',sans-serif;transition:color .15s,border-color .15s}
.revenue-tab:hover{color:var(--text)}
.revenue-tab--active{color:var(--teal-light);border-bottom-color:var(--teal-light)}
.staff-range-btn{padding:.35rem .9rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--gray2);cursor:pointer;font-size:.82rem;transition:all .15s}
.staff-range-btn:hover{border-color:var(--teal);color:var(--text)}
.staff-range-btn--active{background:var(--teal);border-color:var(--teal);color:#fff}

/* ===== ФАЗА 15 — Виджет таймера смены ===== */
.shift-timer-block{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:.9rem 1.25rem;margin-bottom:1.25rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.shift-timer-block__status{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}
.shift-timer-block__elapsed{font-family:'Oswald',sans-serif;font-size:1.5rem;font-weight:600;color:var(--teal-light);letter-spacing:.04em}
.shift-timer-block__actions{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.shift-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;white-space:nowrap}
.shift-badge--open{background:rgba(13,205,173,.15);color:#14cdad}
.shift-badge--paused{background:rgba(232,160,32,.15);color:var(--amber,#e8a020)}
.shift-badge--closed{background:rgba(100,116,139,.15);color:var(--gray2)}
.shift-badge--none{background:rgba(100,116,139,.1);color:var(--gray2)}
.admin-btn--danger{background:#ef476f;color:#fff;border:none}
.admin-btn--danger:hover{background:#c73458}
@media(max-width:600px){.shift-timer-block{flex-direction:column;align-items:flex-start;gap:.6rem}}

/* ─── Auth pages: password eye toggle, input validation ───────── */
.password-field-wrap { position: relative; }
.password-field-wrap input { padding-right: 44px !important; }
.password-eye-btn {
    position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
    background: none; border: none; cursor: pointer; color: var(--gray2);
    display: flex; align-items: center; padding: 4px; transition: color var(--transition);
}
.password-eye-btn:hover { color: var(--teal-light); }
.input-error { border-color: #ef4444 !important; box-shadow: 0 0 0 2px rgba(239,68,68,.15) !important; }
.input-success { border-color: #22c55e !important; box-shadow: 0 0 0 2px rgba(34,197,94,.15) !important; }
.password-match-hint { font-size: .78rem; margin-top: 4px; min-height: 1.1rem; }
.password-match-hint--ok  { color: #22c55e; }
.password-match-hint--err { color: #ef4444; }

/* ═══════════════════════════════════════════════════════════════════
   AUTH PAGES — login.html / register.html
   ═══════════════════════════════════════════════════════════════════ */
.auth-page {
  min-height: calc(100vh - 72px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 16px 48px;
}
.auth-card {
  width: 100%;
  max-width: 400px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 36px 32px 28px;
}
@media(max-width:480px) {
  .auth-card { padding: 28px 20px 24px; border-radius: 12px; }
}
.auth-card__logo {
  display: flex;
  justify-content: center;
  margin-bottom: 16px;
}
.auth-card__title {
  font-family: var(--font-h);
  font-size: 1.5rem;
  font-weight: 700;
  text-align: center;
  margin: 0 0 4px;
  color: var(--white);
}
.auth-card__sub {
  text-align: center;
  font-size: .82rem;
  color: var(--gray2);
  margin: 0 0 24px;
}
.auth-alert {
  border-radius: 8px;
  padding: 10px 14px;
  font-size: .85rem;
  margin-bottom: 18px;
  line-height: 1.45;
}
.auth-alert--error {
  background: rgba(239,68,68,.1);
  border: 1px solid rgba(239,68,68,.3);
  color: #f87171;
}
.auth-field {
  margin-bottom: 16px;
}
.auth-label {
  display: block;
  font-size: .8rem;
  font-weight: 600;
  color: var(--gray);
  margin-bottom: 6px;
  letter-spacing: .02em;
}
.auth-required { color: var(--teal-light); margin-left: 2px; }
.auth-input {
  width: 100%;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 11px 14px;
  font-size: .9375rem;
  color: var(--white);
  outline: none;
  font-family: var(--font-b);
  transition: border-color .2s, box-shadow .2s;
  box-sizing: border-box;
}
.auth-input:focus { border-color: var(--teal); box-shadow: 0 0 0 3px rgba(13,115,119,.18); }
.auth-input::placeholder { color: var(--gray2); }
.auth-input--narrow { width: 100%; max-width: 200px; min-width: 80px; }
.auth-input--ok  { border-color: #22c55e !important; box-shadow: 0 0 0 2px rgba(34,197,94,.15) !important; }
.auth-input--err { border-color: #ef4444 !important; box-shadow: 0 0 0 2px rgba(239,68,68,.15) !important; }
/* password wrapper */
.auth-password-wrap { position: relative; }
.auth-password-wrap .auth-input { padding-right: 42px; }
.auth-eye-btn {
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; color: var(--gray2);
  display: flex; align-items: center; padding: 4px;
  transition: color .2s;
}
.auth-eye-btn:hover { color: var(--teal-light); }
/* password match hint */
.auth-match-hint { font-size: .76rem; margin-top: 4px; min-height: 1rem; }
.auth-match-hint--ok  { color: #22c55e; }
.auth-match-hint--err { color: #ef4444; }
/* consent */
.auth-consent { margin-bottom: 20px; }
.auth-consent__label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  font-size: .85rem;
  color: var(--gray);
  line-height: 1.45;
}
.auth-consent__label input[type="checkbox"] { margin-top: 2px; flex-shrink: 0; accent-color: var(--teal); width: 16px; height: 16px; cursor: pointer; }
.auth-docs-link {
  background: none; border: none; cursor: pointer;
  color: var(--teal-light); text-decoration: underline;
  font-size: inherit; font-family: inherit; padding: 0;
  transition: color .2s;
}
.auth-docs-link:hover { color: var(--white); }
/* submit button */
.auth-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 13px 24px;
  border: none;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--teal), var(--teal-light));
  color: #fff;
  font-size: .9375rem;
  font-weight: 700;
  font-family: var(--font-b);
  cursor: pointer;
  transition: opacity .2s, transform .15s, box-shadow .2s;
  box-shadow: 0 4px 16px rgba(13,115,119,.35);
  margin-bottom: 16px;
}
.auth-submit:hover { opacity: .92; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(13,115,119,.45); }
.auth-submit:active { transform: translateY(0); }
/* footer link */
.auth-footer-link {
  text-align: center;
  font-size: .85rem;
  color: var(--gray2);
}
.auth-footer-link a { color: var(--teal-light); text-decoration: none; font-weight: 600; }
.auth-footer-link a:hover { text-decoration: underline; }

/* ── Nav login button — more prominent ──────────────────────────── */
.nav-btn--login {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 18px;
  border-radius: 8px;
  border: 1.5px solid var(--teal);
  color: var(--teal-light) !important;
  font-size: .875rem;
  font-weight: 600;
  background: rgba(13,115,119,.08);
  transition: all .2s;
  text-decoration: none !important;
}
.nav-btn--login:hover {
  background: var(--teal);
  color: #fff !important;
  border-color: var(--teal);
}
.nav-btn--login .nav-btn__avatar-placeholder {
  background: rgba(13,115,119,.2);
}

/* ══════════════════════════════════════════════════════════════════
   DOCS MODAL
   ════════════════════════════════════════════════════════════════ */
.docs-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,.65);
  z-index: 1100;
}
.docs-overlay--open { display: block; }
.docs-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1101;
  margin: auto;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  max-width: 520px;
  max-height: 85vh;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  flex-direction: column;
  overflow: hidden;
}
.docs-modal--open { display: flex; }
.docs-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.docs-modal__title { font-size: .95rem; font-weight: 700; color: var(--white); }
.docs-modal__close {
  background: none; border: none; cursor: pointer;
  color: var(--gray2); padding: 4px; border-radius: 6px;
  display: flex; align-items: center; transition: color .15s;
}
.docs-modal__close:hover { color: var(--white); }
.docs-modal__body {
  flex: 1;
  overflow-y: auto;
  padding: 12px 16px;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
.docs-modal__footer {
  padding: 14px 20px;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 14px;
  flex-shrink: 0;
  background: var(--surface2);
}
/* docs accordion blocks */
.docs-block {
  border: 1px solid var(--border);
  border-radius: 10px;
  margin-bottom: 10px;
  overflow: hidden;
}
.docs-block__head {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  background: var(--surface2);
  border: none;
  cursor: pointer;
  color: var(--gray);
  font-size: .85rem;
  font-weight: 600;
  font-family: var(--font-b);
  text-align: left;
  transition: color .15s, background .15s;
}
.docs-block__head:hover { color: var(--white); background: rgba(255,255,255,.05); }
.docs-block--open .docs-block__head { color: var(--teal-light); }
.docs-chevron {
  margin-left: auto;
  transition: transform .2s;
  flex-shrink: 0;
}
.docs-block--open .docs-chevron { transform: rotate(180deg); }
.docs-block__content {
  display: none;
  padding: 12px 14px 14px;
  font-size: .83rem;
  color: var(--gray);
  line-height: 1.6;
  border-top: 1px solid var(--border);
}
.docs-block--open .docs-block__content { display: block; }
.docs-block__content p { margin: 0 0 8px; }
.docs-block__content ul { margin: 0 0 8px; padding-left: 18px; }
.docs-block__content li { margin-bottom: 4px; }
/* consent check in footer */
.docs-consent-check {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .82rem;
  color: var(--gray);
  cursor: pointer;
  flex: 1;
}
.docs-consent-check input { accent-color: var(--teal); width: 15px; height: 15px; cursor: pointer; }
.docs-confirm-btn {
  flex-shrink: 0;
  padding: 9px 20px;
  border-radius: 8px;
  border: none;
  background: linear-gradient(135deg, var(--teal), var(--teal-light));
  color: #fff;
  font-size: .85rem;
  font-weight: 700;
  font-family: var(--font-b);
  cursor: pointer;
  transition: opacity .2s;
}
.docs-confirm-btn:disabled { opacity: .4; cursor: not-allowed; }
.docs-confirm-btn:not(:disabled):hover { opacity: .88; }

/* Confirm delete dialog (admin) */
#confirmDeleteModal::backdrop { background: rgba(0,0,0,.55); }
#confirmDeleteModal[open] { display: block; }

/* ─── Nav Logo + Register Btn ─── */
.nav-logo-img { height: 48px; width: auto; display: block; }
@media (max-width: 768px) { .nav-logo-img { height: 36px; } }

.nav-links a { font-size: .9375rem; font-weight: 600; letter-spacing: .03em; text-transform: uppercase; }

.nav-btn--register { color: var(--teal-light); border: 1px solid var(--teal); padding: 8px 18px; border-radius: var(--r, 8px); font-size: .875rem; font-weight: 600; text-decoration: none; transition: all .2s; white-space: nowrap; }
.nav-btn--register:hover { background: var(--teal); color: var(--white, #fff); }

/* ─── Footer Address Link ─── */
.footer-address-link { color: var(--gray2); text-decoration: none; line-height: 1.8; display: block; transition: color .2s; }
.footer-address-link:hover { color: var(--teal-light); }

/* ─── Confirm Delete Dialog ─── */
.confirm-delete-dialog { background: var(--surface, #1a1d23); color: var(--text, #e6e6e6); border: 1px solid var(--border, #23272f); border-radius: 16px; padding: 2rem; max-width: 400px; width: 90vw; box-shadow: 0 24px 64px rgba(0,0,0,.6); }
.confirm-delete-dialog::backdrop { background: rgba(0,0,0,.5); }

/* ─── Chatbot FAB + Window ─── */
.chatbot-fab { position: fixed; bottom: 88px; right: 20px; z-index: 900; width: 56px; height: 56px; border-radius: 50%; background: linear-gradient(135deg, var(--teal, #0d7377), var(--teal-light, #14cdad)); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 20px rgba(13,115,119,0.45); transition: transform .2s, box-shadow .2s; }
.chatbot-fab:hover { transform: scale(1.08); box-shadow: 0 6px 28px rgba(13,115,119,0.55); }
.chatbot-fab--hidden { opacity: 0; pointer-events: none; transform: scale(0.85); }
.chatbot-fab__icon { font-size: 1.5rem; line-height: 1; }
.chatbot-window { position: fixed; bottom: 88px; right: 20px; z-index: 901; width: 360px; max-width: calc(100vw - 32px); height: 520px; max-height: calc(100vh - 110px); background: var(--surface, #1a1d24); border: 1px solid var(--border, #23272f); border-radius: 20px; display: flex; flex-direction: column; box-shadow: 0 16px 56px rgba(0,0,0,.6); transform: translateY(20px) scale(0.96); opacity: 0; pointer-events: none; transition: transform .25s cubic-bezier(.4,0,.2,1), opacity .25s; }
.chatbot-window--open { transform: translateY(0) scale(1); opacity: 1; pointer-events: auto; }
.chatbot-header { display: flex; align-items: center; padding: 14px 16px; border-bottom: 1px solid var(--border, #23272f); gap: 8px; }
.chatbot-header__title { flex: 1; font-weight: 700; font-size: .95rem; color: var(--white, #e6e6e6); }
.chatbot-header__actions { display: flex; gap: 4px; }
.chatbot-header__voice-toggle { background: none; border: none; cursor: pointer; font-size: 1.1rem; padding: 4px; border-radius: 6px; opacity: .4; transition: opacity .2s; }
.chatbot-header__voice-toggle--on { opacity: 1; }
.chatbot-header__close { background: none; border: none; cursor: pointer; font-size: 1.4rem; color: var(--gray2, #888); padding: 4px 6px; border-radius: 6px; line-height: 1; transition: color .2s; }
.chatbot-header__close:hover { color: var(--white, #e6e6e6); }
.chatbot-messages { flex: 1; overflow-y: auto; padding: 12px; display: flex; flex-direction: column; gap: 8px; scrollbar-width: thin; scrollbar-color: var(--border) transparent; }
.chatbot-msg { display: flex; }
.chatbot-msg--user { justify-content: flex-end; }
.chatbot-msg--assistant { justify-content: flex-start; }
.chatbot-msg__bubble { max-width: 80%; padding: 9px 13px; border-radius: 14px; font-size: .875rem; line-height: 1.5; white-space: pre-wrap; word-break: break-word; }
.chatbot-msg--user .chatbot-msg__bubble { background: var(--teal, #0d7377); color: #fff; border-bottom-right-radius: 4px; }
.chatbot-msg--assistant .chatbot-msg__bubble { background: var(--surface2, #23272f); color: var(--white, #e6e6e6); border-bottom-left-radius: 4px; }
.chatbot-typing { padding: 8px 12px; display: flex; gap: 4px; align-items: center; }
.chatbot-typing__dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gray2, #888); animation: pulse 1.2s infinite; }
.chatbot-typing__dot:nth-child(2) { animation-delay: .2s; }
.chatbot-typing__dot:nth-child(3) { animation-delay: .4s; }
.chatbot-input { display: flex; align-items: center; gap: 6px; padding: 10px 12px; border-top: 1px solid var(--border, #23272f); }
.chatbot-input__field { flex: 1; background: var(--surface2, #23272f); border: 1px solid var(--border, #23272f); border-radius: 10px; color: var(--white, #e6e6e6); padding: 8px 12px; font-size: .875rem; outline: none; transition: border-color .2s; }
.chatbot-input__field:focus { border-color: var(--teal, #0d7377); }
.chatbot-input__send { background: var(--teal, #0d7377); border: none; border-radius: 10px; color: #fff; padding: 8px 14px; cursor: pointer; font-size: .875rem; transition: background .2s; white-space: nowrap; }
.chatbot-input__send:hover { background: var(--teal-light, #14cdad); }
.chatbot-input__mic { background: none; border: 1px solid var(--border, #23272f); border-radius: 10px; color: var(--gray2, #888); padding: 8px 10px; cursor: pointer; font-size: 1rem; transition: all .2s; }
.chatbot-input__mic:hover { border-color: var(--teal, #0d7377); color: var(--teal-light, #14cdad); }
.chatbot-input__mic--recording { border-color: var(--red, #e74c3c); color: var(--red, #e74c3c); animation: pulse 1s infinite; }
@media (max-width: 480px) { .chatbot-window { width: calc(100vw - 24px); right: 12px; bottom: 80px; } .chatbot-fab { right: 12px; bottom: 80px; } }

/* ─── Filter Pills Arrows ─── */
.filter-pills-wrapper { position: relative; display: flex; align-items: center; }
.filter-arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 2; background: var(--surface, #1a1d24); border: 1px solid var(--border, #23272f); color: var(--white, #e6e6e6); width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 1.1rem; transition: background .2s; padding: 0; line-height: 1; }
.filter-arrow:hover { background: var(--surface2, #23272f); }
.filter-arrow--left { left: 0; }
.filter-arrow--right { right: 0; }

/* ─── Verification Cards ─── */
.verify-card { transition: border-color .2s, transform .2s; }
.verify-card:not(.verify-card--soon):hover { border-color: var(--teal, #0d7377) !important; transform: translateY(-2px); }

/* ─── Bike Gallery ─── */
.bike-gallery { position: relative; width: 100%; aspect-ratio: 4/3; overflow: hidden; border-radius: 12px; background: var(--surface, #1a1d24); }
.bike-gallery__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity .35s; }
.bike-gallery__img.active { opacity: 1; }
.gallery-arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 3; background: rgba(0,0,0,.45); border: none; color: #fff; width: 36px; height: 36px; border-radius: 50%; font-size: 1.4rem; line-height: 1; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: background .2s; }
.gallery-arrow:hover { background: rgba(0,0,0,.7); }
.gallery-arrow--left { left: 8px; }
.gallery-arrow--right { right: 8px; }
.gallery-dots { position: absolute; bottom: 8px; left: 50%; transform: translateX(-50%); display: flex; gap: 5px; z-index: 3; }
.gallery-dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,.4); cursor: pointer; transition: background .2s; }
.gallery-dot.active { background: #fff; }

/* ─── Verify icons in admin badge ─── */
.admin-badge--warning { background: rgba(234,179,8,.12); color: #f59e0b; border-color: rgba(234,179,8,.25); }

/* ─── Rent action button — rent variant ─── */
.rent-action-btn--rent { display: inline-flex; align-items: center; gap: 8px; padding: 12px 24px; border-radius: 10px; font-size: .95rem; font-weight: 600; text-decoration: none; transition: opacity .2s, transform .15s; }
.rent-action-btn--rent:hover { opacity: .88; transform: translateY(-1px); }

/* ─── Admin table responsive ─── */
@media (max-width: 768px) {
  .admin-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .admin-table { min-width: 700px; }
  .admin-page__header { flex-wrap: wrap; gap: .5rem; }
  .admin-topbar { flex-wrap: wrap; gap: .5rem; }
  .admin-topbar__datetime { font-size: .75rem; }
}
@media (max-width: 480px) {
  .admin-table { min-width: 560px; font-size: .8rem; }
  .admin-btn { font-size: .78rem; padding: .3rem .55rem; }
  .shift-dashboard { flex-direction: column; }
  .shift-dashboard__metrics { flex-direction: row; flex-wrap: wrap; }
}


/* ─── Bike Card Redesign — rent page (added 2026-04-16) ─── */
.bike-card__body { padding:24px; }
.bike-card__header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:12px; }
.bike-card__title { font-size:1.5rem; font-weight:700; margin:0; color:var(--white); }
.bike-card__price { font-size:1.3rem; font-weight:700; color:var(--teal-light); white-space:nowrap; }
.bike-card__category { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.bike-card__tag { background:var(--surface2); padding:4px 12px; border-radius:8px; font-size:.8rem; color:var(--gray2); }
.bike-card__rating { font-size:.9rem; color:var(--amber,#f59e0b); }
.bike-card__desc { color:var(--gray2); font-size:.9rem; line-height:1.6; margin-bottom:20px; }
.bike-card__availability { font-size:.85rem; margin-bottom:12px; padding:6px 12px; border-radius:8px; }
.bike-card__availability--ok { background:rgba(34,197,94,0.1); color:#22c55e; }
.bike-card__availability--none { background:rgba(239,68,68,0.1); color:#ef4444; }
.bike-card__alert { background:rgba(234,179,8,0.1); color:#eab308; font-size:.85rem; padding:10px 14px; border-radius:8px; margin-bottom:16px; border:1px solid rgba(234,179,8,0.2); }
.bike-card__qr { display:flex; align-items:center; gap:16px; padding:16px; background:var(--bg); border-radius:12px; margin-bottom:20px; }
.bike-card__qr-img { width:80px; height:80px; border-radius:8px; background:#fff; padding:4px; }
.bike-card__qr-actions { display:flex; flex-direction:column; gap:4px; }
.bike-card__qr-label { font-size:.8rem; color:var(--gray2); }
.bike-card__qr-print { font-size:.8rem; color:var(--teal-light); text-decoration:none; }
.bike-card__qr-print:hover { text-decoration:underline; }
.bike-card__rent-btn { display:block; width:100%; padding:16px; background:linear-gradient(135deg,var(--teal),var(--teal-light)); color:#fff; font-size:1.1rem; font-weight:700; text-align:center; text-decoration:none; border-radius:14px; margin-bottom:16px; transition:transform 0.2s,box-shadow 0.2s; box-shadow:0 4px 20px rgba(13,115,119,0.3); border:none; cursor:pointer; }
.bike-card__rent-btn:hover { transform:translateY(-2px); box-shadow:0 6px 28px rgba(13,115,119,0.4); }
.bike-card__rent-btn--disabled { background:linear-gradient(135deg,#3a3d44,#555); box-shadow:none; cursor:not-allowed; opacity:.6; }
.bike-card__rent-btn--disabled:hover { transform:none; box-shadow:none; }
.bike-card__contacts { display:flex; gap:12px; margin-bottom:20px; }
.bike-card__contact-btn { flex:1; padding:12px; text-align:center; background:var(--surface2); color:var(--text); text-decoration:none; border-radius:10px; font-size:.85rem; transition:background 0.2s; }
.bike-card__contact-btn:hover { background:var(--border); }
.bike-card__contact-btn--wa:hover { background:#25D366; color:#fff; }
.bike-card__back { display:inline-block; margin-top:8px; color:var(--gray2); text-decoration:none; font-size:.85rem; }
.bike-card__back:hover { color:var(--teal-light); }

/* ─── Verification Icons ─── */
.verify-icon { display:inline-flex; align-items:center; justify-content:center; width:28px; height:28px; border-radius:50%; font-size:0.9rem; font-weight:700; }
.verify-icon--green { background:rgba(34,197,94,0.15); color:#22c55e; }
.verify-icon--yellow { background:rgba(234,179,8,0.15); color:#eab308; }
.verify-icon--red { background:rgba(239,68,68,0.15); color:#ef4444; }

/* ─── Admin table column visibility ─── */
@media (max-width:1200px) { .admin-table .col-email { display:none; } }
@media (max-width:1024px) { .admin-table .col-rentals { display:none; } .admin-table td, .admin-table th { padding:8px 6px; font-size:.8rem; } }
@media (max-width:768px) { .admin-table .col-rate { display:none; } .table-responsive { overflow-x:auto; -webkit-overflow-scrolling:touch; } .table-responsive .admin-table { min-width:700px; } }
@media (max-width:480px) { .admin-table td, .admin-table th { padding:6px 4px; font-size:.75rem; } }

/* ===== TASK-009 — Футер АДРЕС ===== */
.app-address-footer{padding:1.5rem 1rem 2rem;text-align:center}
.app-address-footer__title{font-family:'Oswald',sans-serif;font-size:1.1rem;font-weight:600;color:var(--gray2);letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem}
.app-address-footer__taxis{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}
.app-address-footer__taxi-btn{display:flex;flex-direction:column;align-items:center;gap:.35rem;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:.75rem 1rem;text-decoration:none;color:var(--text);transition:border-color .2s,background .2s;min-width:90px;cursor:pointer}
.app-address-footer__taxi-btn:hover{border-color:var(--teal);background:var(--surface2)}
.app-address-footer__taxi-btn--inactive{opacity:.45;cursor:default;pointer-events:none}
.app-address-footer__taxi-icon{font-size:1.6rem;line-height:1}
.app-address-footer__taxi-label{font-size:.72rem;color:var(--gray2);white-space:nowrap}

/* ═══════ MAP PAGE ═══════ */
.map-page { padding: 0.75rem; }
.map-page__header { margin-bottom: 1rem; }
.map-page__title { font-family: 'Oswald', sans-serif; font-size: 1.5rem; color: #e2e8f0; margin: 0; }
.map-page__subtitle { color: #94a3b8; font-size: 0.85rem; margin: 0.25rem 0 0; }

.map-page__info-card {
  position: fixed;
  bottom: 80px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 2rem);
  max-width: 400px;
  background: #151a25;
  border-radius: 20px;
  padding: 1.25rem;
  z-index: 1000;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  animation: slideUp 0.25s ease-out;
}
@keyframes slideUp {
  from { transform: translateX(-50%) translateY(20px); opacity: 0; }
  to { transform: translateX(-50%) translateY(0); opacity: 1; }
}
.map-page__info-close {
  position: absolute; top: 0.75rem; right: 0.75rem;
  background: none; border: none; color: #94a3b8; font-size: 1.5rem; cursor: pointer; padding: 0; line-height: 1;
}
.map-page__info-name { font-family: 'Oswald', sans-serif; font-size: 1.15rem; color: #e2e8f0; margin: 0 0 0.5rem; }
.map-page__info-address { color: #94a3b8; font-size: 0.85rem; margin: 0 0 0.25rem; }
.map-page__info-hours { color: #94a3b8; font-size: 0.85rem; margin: 0 0 0.75rem; }
.map-page__info-bikes { font-size: 1.1rem; margin-bottom: 0.75rem; }
.map-page__info-route {
  display: inline-block;
  padding: 0.6rem 1.5rem;
  background: #0D7377;
  color: #fff;
  text-decoration: none;
  border-radius: 14px;
  font-size: 0.9rem;
  transition: background 0.2s;
}
.map-page__info-route:hover { background: #14cdad; }

#map { filter: brightness(0.85) contrast(1.05); }
