/* SLCS Frontend CSS — v2.2 */
:root{
  --slcs-bg:transparent;--slcs-card:transparent;--slcs-border:#c9a882;
  --slcs-muted:#5a3e28;--slcs-text:#2d1a0a;--slcs-radius:18px;
  --slcs-shadow:none;
}
/* Page background — website background sanga match */
.slcs-wrap{
  background:transparent !important;
}
.slcs-wrap{display:flex;justify-content:center;padding:0 0 32px;min-height:50vh;font-family:'Hiragino Kaku Gothic ProN','Noto Sans JP',sans-serif;}
.slcs-card{background:#f6e8cc;border-radius:var(--slcs-radius);box-shadow:0 4px 24px rgba(100,60,10,.10);width:100%;max-width:460px;overflow:hidden;box-sizing:border-box;border:1px solid rgba(201,168,130,0.3);}
.slcs-staff-card{max-width:520px;}

/* Banner */
.slcs-banner{padding:24px 20px 18px;text-align:center;}
.slcs-banner-emoji{font-size:2.2rem;line-height:1;margin-bottom:6px;}
.slcs-banner-title{font-size:1.1rem;font-weight:700;margin-bottom:4px;}
.slcs-banner-discount{font-size:1.9rem;font-weight:900;letter-spacing:1px;}
.slcs-banner-sub{font-size:.85rem;opacity:.9;margin-top:4px;}
.slcs-banner-expiry{font-size:.8rem;opacity:.85;margin-top:4px;}

/* Form body */
.slcs-form-body{padding:16px 22px 20px;}
.slcs-btn-line{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:15px;border-radius:12px;background:#06C755;color:#fff;border:none;font-size:1rem;font-weight:700;cursor:pointer;text-decoration:none;box-sizing:border-box;transition:opacity .18s;}
.slcs-btn-line:hover{opacity:.88;text-decoration:none;color:#fff;}
.slcs-divider{display:flex;align-items:center;gap:10px;color:var(--slcs-muted);font-size:.85rem;margin:16px 0;}
.slcs-divider::before,.slcs-divider::after{content:'';flex:1;height:1px;background:var(--slcs-border);}
.slcs-field{margin-bottom:14px;}
.slcs-field label{display:block;font-size:.85rem;font-weight:600;margin-bottom:5px;color:var(--slcs-text);}
.slcs-field input{width:100%;padding:12px 14px;border:1.5px solid var(--slcs-border);border-radius:10px;font-size:1rem;box-sizing:border-box;font-family:inherit;-webkit-appearance:none;transition:border-color .18s;}
.slcs-field input:focus{outline:none;border-color:#06C755;box-shadow:0 0 0 3px rgba(6,199,85,.12);}
.slcs-field-hint{font-size:.75rem;color:var(--slcs-muted);margin:4px 0 0;}
.slcs-consent-row{display:flex;align-items:flex-start;gap:8px;font-size:.82rem;color:var(--slcs-muted);margin-bottom:14px;line-height:1.6;}
.slcs-consent-row input{margin-top:3px;flex-shrink:0;}
.slcs-btn-primary{display:block;width:100%;padding:15px;border-radius:12px;border:none;font-size:1rem;font-weight:700;cursor:pointer;color:#fff;transition:opacity .18s;font-family:inherit;}
.slcs-btn-primary:hover{opacity:.88;}
.slcs-btn-ghost{background:transparent;color:var(--slcs-muted);border:1px solid var(--slcs-border);border-radius:8px;padding:9px 18px;font-size:.85rem;cursor:pointer;font-family:inherit;}
.slcs-privacy{font-size:.72rem;color:var(--slcs-muted);text-align:center;margin:14px 0 0;line-height:1.7;}
.slcs-alert{padding:10px 14px;border-radius:8px;font-size:.875rem;margin-bottom:12px;}
.slcs-alert-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;}

/* Coupon image */
.slcs-coupon-img-wrap{padding:0 20px;margin-bottom:4px;}
.slcs-coupon-img{width:100%;border-radius:12px;display:block;}

/* QR section */
.slcs-qr-section{text-align:center;margin-bottom:8px;}
.slcs-qr-label-bar{padding:10px 14px;font-weight:700;font-size:.9rem;margin:0 20px;border-radius:12px 12px 0 0;}
.slcs-qr-box{display:inline-flex;align-items:center;justify-content:center;padding:16px;background:#fff;border:3px solid #06C755;border-top:none;border-radius:0 0 14px 14px;margin:0 20px;min-height:200px;}
.slcs-qr-box svg,.slcs-qr-box img,.slcs-qr-code svg{display:block;margin:0 auto;}
.slcs-qr-code{display:flex;justify-content:center;}
.slcs-user-name{font-weight:600;margin:10px 0 0;font-size:.95rem;}

/* Used stamp */
.slcs-used-stamp{text-align:center;padding:24px 20px;}
.slcs-stamp{display:inline-block;border:3px solid #16a34a;color:#16a34a;font-size:1.3rem;font-weight:900;padding:10px 28px;border-radius:8px;transform:rotate(-3deg);letter-spacing:2px;margin-bottom:10px;}
.slcs-stamp.large{font-size:1.6rem;padding:14px 36px;}
.slcs-used-time{font-size:.8rem;color:var(--slcs-muted);margin:4px 0 0;}

/* Instructions */
.slcs-instructions{background:#fffbeb;border:1px solid #fde68a;border-radius:10px;margin:0 20px 14px;padding:12px 16px;font-size:.83rem;line-height:1.9;}
.slcs-instructions p{margin:0;}
.slcs-logout-area{text-align:center;padding:8px 20px 22px;}

/* Staff page */
.slcs-staff-body{padding:20px;}
.slcs-valid-badge{text-align:center;padding:12px;border-radius:10px;font-size:1rem;font-weight:700;margin-bottom:16px;}
.slcs-staff-table{width:100%;border-collapse:collapse;margin-bottom:16px;}
.slcs-staff-table th,.slcs-staff-table td{padding:8px 12px;border-bottom:1px solid #e5e7eb;font-size:.9rem;vertical-align:top;}
.slcs-staff-table th{font-weight:600;color:var(--slcs-muted);width:35%;white-space:nowrap;}
.slcs-badge{background:#e5e7eb;border-radius:20px;padding:2px 8px;font-size:.72rem;font-weight:700;color:#374151;}
.slcs-badge-line{background:#dcfce7;color:#16a34a;}
.slcs-badge-email{background:#dbeafe;color:#1d4ed8;}
.slcs-badge-phone{background:#fef3c7;color:#92400e;}
.slcs-staff-notice-used{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px 16px;color:#b91c1c;font-size:.9rem;}
.slcs-staff-coupon-img{width:100%;max-width:300px;border-radius:10px;display:block;margin:0 auto 16px;}
.slcs-btn-use{display:block;width:100%;padding:16px;border-radius:12px;border:none;font-size:1.1rem;font-weight:700;cursor:pointer;transition:opacity .18s;font-family:inherit;margin-top:8px;}
.slcs-btn-use:hover{opacity:.88;}
.slcs-btn-use:disabled{opacity:.5;cursor:not-allowed;}

/* ── Countdown ───────────────────────────────────────── */
.slcs-countdown-section{padding:16px 20px 8px;}
.slcs-countdown-wrap{text-align:center;background:#f6e8cc;border-radius:14px;padding:18px 16px 14px;margin-bottom:14px;border:1px solid #c9a882;}
.slcs-countdown-label{font-size:.82rem;color:#6b7280;font-weight:600;margin-bottom:12px;}
.slcs-dots{display:flex;justify-content:center;gap:8px;margin-bottom:10px;flex-wrap:wrap;}
.slcs-dot{width:22px;height:22px;border-radius:50%;display:inline-block;transition:all .3s;}
.slcs-dot.active{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.2);}
.slcs-dot.used{background:#d1d5db;}
.slcs-count-num{margin-top:4px;}

/* USE button */
.slcs-btn-use{display:block;width:100%;padding:18px;border-radius:14px;border:none;font-size:1.15rem;font-weight:800;cursor:pointer;transition:opacity .18s,transform .1s;font-family:inherit;letter-spacing:.5px;margin-bottom:8px;}
.slcs-btn-use:hover{opacity:.88;}
.slcs-btn-use:active{transform:scale(.97);}
.slcs-btn-use:disabled{opacity:.5;cursor:not-allowed;}
.slcs-staff-hint{text-align:center;font-size:.72rem;color:#9ca3af;padding:4px 0 10px;line-height:1.5;}

/* All used */
.slcs-all-used{text-align:center;padding:24px 16px;}
.slcs-stamp{display:inline-block;border:3px solid #6b7280;color:#6b7280;font-size:1.1rem;font-weight:900;padding:8px 22px;border-radius:8px;letter-spacing:2px;margin-bottom:10px;}

/* Social follow */
.slcs-follow-section{padding:4px 20px 8px;border-top:1px solid #f3f4f6;margin-top:4px;}
.slcs-follow-title{font-size:.85rem;font-weight:700;color:#374151;margin:12px 0 10px;text-align:center;}
.slcs-follow-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px 16px;border-radius:10px;font-size:.95rem;font-weight:700;text-decoration:none;margin-bottom:8px;box-sizing:border-box;transition:opacity .18s;}
.slcs-follow-btn:hover{opacity:.88;text-decoration:none;}
.slcs-follow-line{background:#06C755;color:#fff;}
.slcs-follow-ig{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:#fff;}
.slcs-follow-fb{background:#1877F2;color:#fff;}
.slcs-follow-item{margin-bottom:8px;}
.slcs-follow-item a{display:block!important;}
