@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=DM+Sans:wght@300;400;500&display=swap";:root{--dark: #1C0F2E;--gold: #C8953D;--gold-light: #E5B86A;--light: #FDF6F6;--white: #FFFFFF;--gray: #8B7E8E;--border: #E8DFE8;--red: #C0392B;--green: #27AE60}*{margin:0;padding:0;box-sizing:border-box}body{font-family:DM Sans,sans-serif;background:var(--light);color:var(--dark);min-height:100vh;-webkit-font-smoothing:antialiased}.header-dark{background:var(--dark);padding:18px 20px;display:flex;justify-content:center;align-items:center}.logo{height:56px;filter:brightness(0) invert(1)}.btn-gold{background:var(--gold);color:var(--white);border:none;padding:14px;border-radius:10px;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s;width:100%}.btn-gold:hover{background:var(--gold-light)}.btn-gold:disabled{opacity:.55;cursor:not-allowed}.btn-link{background:none;border:none;color:var(--gold);cursor:pointer;font-size:.9rem;text-decoration:underline;text-align:center;font-family:DM Sans,sans-serif}.btn-outline{background:none;border:1.5px solid var(--border);color:var(--gray);padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.875rem;font-family:DM Sans,sans-serif}input{width:100%;padding:14px 16px;border:1.5px solid var(--border);border-radius:10px;font-family:DM Sans,sans-serif;font-size:1rem;background:var(--white);color:var(--dark);outline:none;transition:border-color .2s}input:focus{border-color:var(--gold)}.register-page{min-height:100vh;display:flex;flex-direction:column}.register-main{flex:1;display:flex;flex-direction:column;align-items:center;padding:40px 24px 60px;max-width:400px;margin:0 auto;width:100%}.register-main h1{font-family:Cormorant Garamond,serif;font-size:2rem;font-weight:500;text-align:center;margin-bottom:6px}.register-sub{color:var(--gray);margin-bottom:36px;font-size:.95rem;text-align:center}form{width:100%;display:flex;flex-direction:column;gap:14px}.error-msg{color:var(--red);font-size:.875rem;text-align:center}.card-page{min-height:100vh;display:flex;flex-direction:column}.card-main{flex:1;padding:24px 16px 48px;max-width:420px;margin:0 auto;width:100%;display:flex;flex-direction:column;align-items:center;gap:20px}.loyalty-card{background:var(--white);border-radius:20px;box-shadow:0 6px 32px #1c0f2e1f;width:100%;overflow:hidden}.card-top{background:var(--dark);padding:22px 20px;text-align:center;color:var(--white)}.card-top h2{font-family:Cormorant Garamond,serif;font-size:1.6rem;font-weight:500}.card-label{font-size:.72rem;color:var(--gold);letter-spacing:.15em;text-transform:uppercase;margin-top:4px}.reward-banner{background:var(--gold);color:var(--white);padding:14px 20px;text-align:center;font-weight:500;font-size:.95rem;line-height:1.4}.stamps-section{padding:24px 20px 8px}.stamps-count{text-align:center;color:var(--gray);font-size:.8rem;margin-bottom:18px;letter-spacing:.08em;text-transform:uppercase}.stamp-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.stamp{aspect-ratio:1;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:transform .2s}.stamp.filled{background:var(--gold);color:var(--white);box-shadow:0 3px 10px #c8953d73}.stamp.empty{background:var(--light);border:2px dashed var(--border)}.stamp.filled{animation:pop .3s ease}@keyframes pop{0%{transform:scale(.8)}60%{transform:scale(1.1)}to{transform:scale(1)}}.qr-section{padding:20px;border-top:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:12px}.qr-label{font-size:.72rem;color:var(--gray);text-transform:uppercase;letter-spacing:.12em}.center-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--gray);font-size:1rem}.admin-page{min-height:100vh;background:#f0ebf4}.admin-header{background:var(--dark);padding:16px 20px;display:flex;align-items:center;gap:12px}.admin-header h1{font-family:Cormorant Garamond,serif;font-size:1.35rem;font-weight:500;color:var(--white);letter-spacing:.04em}.admin-main{padding:20px 16px 60px;max-width:500px;margin:0 auto;display:flex;flex-direction:column;gap:18px}.btn-scan{background:var(--dark);color:var(--white);border:none;padding:16px;border-radius:14px;font-size:1rem;font-weight:500;cursor:pointer;width:100%;font-family:DM Sans,sans-serif;letter-spacing:.03em;transition:opacity .2s}.btn-scan:hover{opacity:.88}.scanner-wrap{background:var(--white);border-radius:16px;overflow:hidden;box-shadow:0 2px 16px #0000001a}.scanner-cancel{display:block;width:100%;padding:13px;background:none;border:none;color:var(--gray);cursor:pointer;font-family:DM Sans,sans-serif;font-size:.9rem}.msg-box{background:var(--white);border-left:4px solid var(--gold);padding:12px 16px;border-radius:10px;font-size:.95rem;box-shadow:0 2px 8px #0000000f}.admin-card{background:var(--white);border-radius:16px;padding:22px 20px;box-shadow:0 2px 16px #00000014;display:flex;flex-direction:column;align-items:center;gap:14px}.admin-card h2{font-family:Cormorant Garamond,serif;font-size:1.55rem;font-weight:500}.admin-card .phone{font-size:.875rem;color:var(--gray);margin-top:-10px}.stamps-counter{font-size:2rem;font-weight:500;color:var(--dark)}.stamp-dots{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;width:100%}.dot{aspect-ratio:1;border-radius:50%;background:var(--light);border:2px dashed var(--border);transition:background .25s}.dot.filled{background:var(--gold);border:none}.btn-stamp{background:var(--green);color:var(--white);border:none;padding:16px;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;width:100%;font-family:DM Sans,sans-serif;letter-spacing:.04em}.btn-stamp:disabled{opacity:.55;cursor:not-allowed}.btn-redeem{background:var(--red);color:var(--white);border:none;padding:16px;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;width:100%;font-family:DM Sans,sans-serif;letter-spacing:.06em;animation:pulse 1.6s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #c0392b66}50%{box-shadow:0 0 0 10px #c0392b00}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:20px;z-index:200}.modal{background:var(--white);border-radius:20px;padding:32px 24px;width:100%;max-width:340px;text-align:center;box-shadow:0 20px 60px #00000040}.modal h3{font-family:Cormorant Garamond,serif;font-size:1.6rem;margin-bottom:8px}.modal p{color:var(--gray);margin-bottom:28px;font-size:.95rem}.modal-btns{display:flex;flex-direction:column;gap:10px}.btn-confirm{background:var(--red);color:var(--white);border:none;padding:15px;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif}.btn-modal-cancel{background:none;border:1.5px solid var(--border);color:var(--gray);padding:13px;border-radius:10px;font-size:1rem;cursor:pointer;font-family:DM Sans,sans-serif}.history-section{background:var(--white);border-radius:16px;padding:20px;box-shadow:0 2px 12px #0000000f}.history-section h3{font-family:Cormorant Garamond,serif;font-size:1.15rem;margin-bottom:16px}.history-empty{color:var(--gray);font-size:.875rem;text-align:center;padding:12px 0}table{width:100%;border-collapse:collapse;font-size:.85rem}th{text-align:left;color:var(--gray);font-weight:400;padding-bottom:10px;border-bottom:1px solid var(--border)}td{padding:10px 0;border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}.badge-stamp{color:var(--green);font-weight:500}.badge-redeem{color:var(--red);font-weight:500}
