:root{--tg-viewport-height: 100vh}*{margin:0;padding:0;box-sizing:border-box}html{height:100%;height:var(--tg-viewport-height);overflow:hidden}body{margin:0;height:100%;height:var(--tg-viewport-height);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f0e7d4;overflow:hidden;position:fixed;width:100%;top:0;left:0}#root{height:100%;height:var(--tg-viewport-height);overflow-y:auto;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.user-page{min-height:100vh;min-height:var(--tg-viewport-height, 100vh);height:100%;background:#f0e7d4;position:relative;display:flex;flex-direction:column;orientation:portrait;overflow-y:auto}@media screen and (orientation: landscape){.user-page{display:none}body:before{content:"Пожалуйста, переверните устройство в вертикальное положение";display:flex;justify-content:center;align-items:center;text-align:center;padding:20px;font-size:18px;color:#23282b;background:#f0e7d4;position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999}}.content{flex:1;display:flex;flex-direction:column;align-items:center;padding:120px 20px 20px;position:relative;z-index:5}.title{margin-bottom:28px;display:flex;justify-content:center}.title svg{width:240px;height:auto}.subtitle{text-align:center;font-size:16px;color:#23282b;margin-bottom:28px;line-height:1.6;font-weight:400}.coffee-cups-container{background:#e4dcc9;border-radius:12px;padding:20px;margin-bottom:40px;width:100%;max-width:380px;display:flex;flex-direction:column;align-items:center}.loyalty-info{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:16px;font-size:15px;color:#23282b}.loyalty-info .count{font-weight:600;font-size:16px}.coffee-cups{display:flex;justify-content:center;gap:10px;margin-bottom:16px;width:100%;overflow-x:auto;flex-wrap:nowrap}.cup{transition:transform .2s;flex-shrink:0}.cup.filled{transform:scale(1.05)}.details-button{background:#d3ccbb;border:none;border-radius:12px;padding:12px 40px;font-size:14px;color:#23282b;cursor:pointer;transition:background .3s;width:100%}.details-button:hover{background:#c8c1b0}.qr-code{display:flex;justify-content:center;align-items:center;margin-bottom:80px}.wave-bottom{position:fixed;bottom:0;left:0;width:100%;height:150px;z-index:1}@media (max-width: 480px){.content{padding-top:108px}.title svg{width:200px;height:auto}.subtitle{font-size:15px}.coffee-cups-container{max-width:calc(100% - 8px);padding:16px 12px}.coffee-cups{gap:6px}.cup svg{width:24px;height:34px}.qr-code svg{width:260px!important;height:260px!important}}.admin-page{max-width:800px;margin:0 auto;padding-top:20px}.admin-page h2{font-size:24px;color:#23282b;margin-bottom:24px;font-weight:600;margin-top:0}.admin-card{background:transparent;border-radius:12px;padding:24px;margin-bottom:20px;box-shadow:none}.admin-icon{font-size:60px;text-align:center;margin-bottom:20px;opacity:.8}.input-group{display:flex;gap:10px;margin-bottom:16px}.input-group input,.input-group textarea,.admin-input{flex:1;padding:12px 16px;border:2px solid #E4DCC9;border-radius:12px;font-size:15px;background:#fff;color:#23282b;transition:border-color .3s}.input-group input:focus,.input-group textarea:focus,.admin-input:focus{outline:none;border-color:#777a43}.input-group textarea{min-height:100px;resize:vertical}.admin-button,.scan-button,.primary-button{background:#d3ccbb;border:none;border-radius:12px;padding:12px 24px;font-size:15px;color:#23282b;cursor:pointer;transition:all .3s;font-weight:500}.admin-button:hover,.scan-button:hover,.primary-button:hover{background:#c8c1b0;transform:translateY(-1px)}.admin-button:disabled,.scan-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.secondary-button{background:#ffffffb3;border:2px solid #E4DCC9;border-radius:12px;padding:10px 20px;font-size:14px;color:#23282b;cursor:pointer;transition:all .3s}.secondary-button:hover{background:#fff;border-color:#777a43}.danger-button{background:#e74c3c;color:#fff;border:none;border-radius:12px;padding:10px 20px;font-size:14px;cursor:pointer;transition:all .3s}.danger-button:hover{background:#c0392b}.alert{padding:16px;border-radius:12px;margin-bottom:20px;font-size:14px}.alert-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.alert-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.alert-info{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.result-card{background:#fff;border-radius:12px;padding:20px;margin-top:20px;border:2px solid #E4DCC9}.result-card h3{color:#23282b;margin-bottom:16px;font-size:18px}.result-info{display:flex;flex-direction:column;gap:12px}.result-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #E4DCC9}.result-row:last-child{border-bottom:none}.result-label{color:#777a43;font-weight:500}.result-value{color:#23282b;font-weight:600}.admin-table{width:100%;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.admin-table table{width:100%;border-collapse:collapse}.admin-table th{background:#e4dcc9;color:#23282b;padding:12px;text-align:left;font-weight:600;font-size:14px}.admin-table td{padding:12px;border-bottom:1px solid #f0f0f0;color:#23282b;font-size:14px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover{background:#f9f9f9}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;padding:20px;text-align:center;box-shadow:0 2px 8px #0000000d}.stat-value{font-size:32px;font-weight:700;color:#777a43;margin-bottom:8px}.stat-label{font-size:14px;color:#666}@media (max-width: 480px){.admin-page{padding-top:10px}.admin-page h2{font-size:20px}.admin-card{padding:16px}.input-group{flex-direction:column}.stats-grid{grid-template-columns:1fr}.admin-table{font-size:12px}.admin-table th,.admin-table td{padding:8px}}.scanner-placeholder{text-align:center;padding:40px 20px}.scanner-placeholder p{color:#777a43;font-size:15px;margin-top:12px;margin-bottom:20px}.scan-start-button{background:#d3ccbb;border:none;border-radius:12px;padding:14px 32px;font-size:16px;color:#23282b;cursor:pointer;transition:all .3s;font-weight:500;margin-top:20px}.scan-start-button:hover{background:#c8c1b0;transform:translateY(-2px);box-shadow:0 4px 12px #777a4333}.scan-start-button:active{transform:translateY(0)}.qr-scanner-container{position:relative;width:100%;max-width:350px;margin:0 auto}.scanner-frame{position:relative;border-radius:16px;overflow:hidden;background:transparent!important;box-shadow:none}#qr-reader{width:100%!important;border:none!important;border-radius:16px;overflow:hidden;background:transparent!important}#qr-reader>div{background:transparent!important}#qr-reader__scan_region>div{background:transparent!important}#qr-reader video{width:100%!important;height:auto!important;border-radius:16px;display:block!important}#qr-reader__scan_region{border:none!important;background:transparent!important}#qr-reader canvas{display:none!important}#qr-reader__dashboard_section,#qr-reader__dashboard_section_csr,#qr-reader__header_message,#qr-reader__camera_selection,#qr-reader__camera_permission_button{display:none!important}.scanner-corners{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:210px;height:210px;pointer-events:none;z-index:10}.corner{position:absolute;width:35px;height:35px;border:3px solid #777A43;box-shadow:0 0 10px #777a434d}.corner-tl{top:0;left:0;border-right:none;border-bottom:none;border-top-left-radius:8px}.corner-tr{top:0;right:0;border-left:none;border-bottom:none;border-top-right-radius:8px}.corner-bl{bottom:0;left:0;border-right:none;border-top:none;border-bottom-left-radius:8px}.corner-br{bottom:0;right:0;border-left:none;border-top:none;border-bottom-right-radius:8px}@keyframes pulse{0%,to{opacity:1;border-color:#777a43}50%{opacity:.7;border-color:#9a9d5e}}.corner{animation:pulse 2s ease-in-out infinite}.scanner-hint{text-align:center;color:#777a43;font-size:14px;margin-top:16px;font-weight:500}.result-icon-large{font-size:64px;text-align:center;margin-bottom:16px;animation:scaleIn .5s cubic-bezier(.4,0,.2,1)}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.result-card{animation:slideUp .4s cubic-bezier(.4,0,.2,1);background:#fff!important;border:2px solid #E4DCC9!important}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.result-card.success{border-color:#777a43!important;background:linear-gradient(135deg,#f9f7f3,#fff)!important}.result-card h3{font-size:20px;margin-bottom:20px;color:#23282b;font-weight:600}@media (max-width: 480px){.qr-scanner-container{max-width:100%}.scanner-corners{width:180px;height:180px}.corner{width:30px;height:30px;border-width:2px}.scanner-hint{font-size:13px}.result-icon-large{font-size:48px}.scanner-placeholder p{font-size:14px}}.admin-dashboard{min-height:100vh;min-height:var(--tg-viewport-height, 100vh);height:100%;background:#f0e7d4;position:relative;display:flex;flex-direction:column;overflow:hidden}.admin-content{flex:1;padding:120px 20px 130px;overflow-y:auto;overflow-x:hidden}.bottom-nav{position:fixed;bottom:32px;left:50%;transform:translate(-50%);z-index:100;width:calc(100% - 32px);max-width:500px}.nav-container{background:#e4dcc9;border-radius:36px;display:flex;justify-content:space-around;align-items:center;padding:14px 10px;box-shadow:0 8px 24px #00000026,0 2px 8px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 8px;text-decoration:none;color:#777a43;transition:all .3s cubic-bezier(.4,0,.2,1);flex:1;position:relative;border-radius:20px}.nav-icon{width:28px;height:28px;margin-bottom:6px;transition:all .3s cubic-bezier(.4,0,.2,1);color:currentColor}.nav-label{font-size:11px;font-weight:600;text-align:center;white-space:nowrap;letter-spacing:.3px;transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-item:hover{background:#ffffff4d}.nav-item:hover .nav-icon{transform:scale(1.1) translateY(-2px)}.nav-item.active{color:#23282b}.nav-item.active .nav-icon{transform:scale(1.15)}.nav-item.active .nav-label{font-weight:700}@keyframes slideUp{0%{transform:translate(-50%) translateY(100px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.bottom-nav{animation:slideUp .4s cubic-bezier(.4,0,.2,1)}@media (max-width: 480px){.admin-content{padding:100px 15px 120px}.bottom-nav{bottom:24px;width:calc(100% - 24px)}.nav-container{padding:12px 8px;border-radius:30px}.nav-icon{width:24px;height:24px;margin-bottom:4px}.nav-label{font-size:10px}.nav-item{padding:10px 6px}}@media (max-width: 380px){.nav-label{font-size:9px}.nav-icon{width:22px;height:22px}}.App{text-align:center}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#5d4e37}
