.subscription-card{background:#fff;border-radius:12px;padding:32px;box-shadow:0 1px 3px #0000000d;border:1px solid #e5e7eb;margin-bottom:24px}.subscription-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #f3f4f6}.subscription-header h3{margin:0;color:#1f2937;font-size:1.25rem;font-weight:600}.status-badge{padding:6px 12px;border-radius:16px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background-color:#ecfdf5;color:#065f46}.status-badge.inactive{background-color:#fef3c7;color:#92400e}.subscription-info{margin-bottom:20px;color:#6b7280;line-height:1.6}.subscription-details{background-color:#f8fafc;padding:20px;border-radius:12px;margin-bottom:24px;border:1px solid #f1f5f9}.subscription-details p{margin:8px 0;color:#475569;font-size:.875rem}.subscription-details strong{color:#1f2937;font-weight:600}.pricing-info{text-align:center;margin-bottom:32px;padding:24px;background-color:#fafbfc;border-radius:12px;border:1px solid #f1f5f9}.price{font-size:2.5rem;font-weight:800;color:#1f2937;margin-bottom:20px}.price .period{font-size:1rem;font-weight:500;color:#6b7280}.features{list-style:none;padding:0;text-align:left;max-width:320px;margin:0 auto}.features li{padding:12px 0;color:#475569;border-bottom:1px solid #f1f5f9;font-size:.875rem}.features li:last-child{border-bottom:none}.subscription-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.subscription-warning{text-align:center}.warning-message{background-color:#fef3c7;color:#92400e;padding:20px;border-radius:12px;margin-bottom:24px;border:1px solid #fcd34d;font-size:.875rem}.loading-state,.error-state{text-align:center;padding:40px 20px}.spinner{width:32px;height:32px;border:3px solid #f3f4f6;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{color:#dc2626;margin-bottom:20px;font-size:.875rem}.btn-primary{background-color:#1f2937;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.875rem}.btn-primary:hover{background-color:#111827;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background-color:#f8fafc;color:#475569;border:1px solid #e2e8f0;padding:12px 24px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.875rem}.btn-secondary:hover{background-color:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px)}.btn-secondary:active{transform:translateY(0)}@media (max-width: 768px){.subscription-card{padding:24px;margin-bottom:16px}.subscription-header{flex-direction:column;align-items:flex-start;gap:12px}.subscription-actions{flex-direction:column;width:100%}.btn-primary,.btn-secondary{width:100%}.price{font-size:2rem}.pricing-info{padding:20px;margin-bottom:24px}}.purchase-treasure-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%;margin:16px 0}.purchase-treasure-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #667eea4d}.purchase-treasure-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.treasure-inventory{background:#fff;padding:24px;border-radius:12px;box-shadow:0 4px 6px #0000000d;border:1px solid #e5e7eb}.treasure-inventory h3{margin:0 0 20px;color:#1f2937;font-size:1.5rem;font-weight:700}.reload-btn{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:8px 16px;border-radius:6px;font-size:.875rem;cursor:pointer;margin-bottom:20px;transition:all .2s ease}.reload-btn:hover:not(:disabled){background:#e5e7eb}.reload-btn:disabled{opacity:.7;cursor:not-allowed}.treasure-list{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:20px;max-width:1200px}@media (max-width: 1100px){.treasure-list{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.treasure-list{grid-template-columns:1fr}}.treasure-card{background:linear-gradient(145deg,#fff,#f8fafc);border:2px solid transparent;border-radius:16px;padding:0;box-shadow:0 8px 25px #00000014,0 2px 8px #0000000a;transition:all .3s ease;overflow:hidden;position:relative;width:100%;height:auto;min-height:400px;display:flex;flex-direction:column}.treasure-card:hover{transform:translateY(-4px);box-shadow:0 12px 35px #0000001f,0 4px 12px #0000000f;border-color:#3b82f6}.treasure-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#06b6d4)}.treasure-header{padding:16px 20px 12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f1f5f9;flex-shrink:0}.gem-icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.status{padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-draft{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;box-shadow:0 2px 4px #fbbf244d}.status-scheduled{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 4px #3b82f64d}.status-released{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 4px #10b9814d}.status-claimed{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;box-shadow:0 2px 4px #f973164d}.status-redeemed{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;box-shadow:0 2px 4px #8b5cf64d}.treasure-content{padding:16px 20px 20px;flex:1;display:flex;flex-direction:column;overflow:hidden}.price-section{margin:8px 0;padding:8px;background:#f8fafc;border-radius:8px;border-left:4px solid #10b981;flex-shrink:0}.price-label{font-size:.75rem;color:#64748b;font-weight:600;margin-bottom:2px}.price{font-size:.9rem;font-weight:700;color:#1e293b}.purchase-date,.treasure-id{margin:8px 0;padding:8px;background:#f8fafc;border-radius:8px;border-left:4px solid #3b82f6;font-size:.8rem;flex-shrink:0}.date-label,.id-label{font-weight:600;color:#374151}.purchase-date,.treasure-id{font-size:.8rem;color:#64748b}.loading,.error,.no-treasures{text-align:center;padding:48px 24px;color:#6b7280;font-style:italic}.error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px}.no-treasures{background:#f8fafc;border:2px dashed #e2e8f0;border-radius:12px}#treasure-section{margin-top:32px;padding:24px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}#treasure-section h3{margin-bottom:16px;color:#2d3748;font-size:24px}.reward-section{margin-top:12px;padding:12px;background:#fefefe;border:2px dashed #e2e8f0;border-radius:12px;flex:1;min-height:0;overflow:hidden}.reward-label{font-weight:600;color:#374151;margin-bottom:8px;font-size:.85rem}.reward-label .required{color:#dc2626;font-weight:700}.reward-required-note{font-size:.75rem;color:#dc2626;margin-top:4px;font-style:italic}.reward-content{display:flex;flex-direction:column;gap:8px;flex:1;min-height:0;overflow:hidden}.reward-textarea{width:100%;padding:8px;border:2px solid #e2e8f0;border-radius:8px;font-family:inherit;font-size:.8rem;resize:none;transition:border-color .2s ease;height:80px;overflow-y:auto}.reward-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.reward-textarea.invalid{border-color:#dc2626}.reward-textarea.invalid:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.reward-textarea:invalid{border-color:#dc2626}.reward-textarea:invalid:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.reward-textarea::placeholder{color:#9ca3af}.save-reward-btn{align-self:flex-start;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.save-reward-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.save-reward-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.reward-display{padding:12px;background:#f8fafc;border-radius:8px;color:#374151;font-style:italic;min-height:40px;display:flex;align-items:center}.lock-note{font-size:.8rem;color:#6b7280;text-align:center;padding:8px;background:#f9fafb;border-radius:6px}.publishing-section{margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}.publishing-label{font-size:.9rem;font-weight:600;color:#374151;margin-bottom:12px;display:flex;align-items:center;gap:8px}.publishing-content{display:flex;flex-direction:column;gap:12px}.published-info{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:12px;border-radius:8px}.published-status{font-weight:600;font-size:.9rem;margin-bottom:6px}.published-details,.published-location{font-size:.8rem;opacity:.9;margin-bottom:4px}.scheduled-info{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;padding:12px;border-radius:8px}.scheduled-status{font-weight:600;font-size:.9rem;margin-bottom:6px}.scheduled-details,.scheduled-city{font-size:.8rem;opacity:.9;margin-bottom:4px}.cancel-publish-btn{margin-top:8px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:6px 12px;border-radius:6px;font-size:.8rem;cursor:pointer;transition:all .2s ease;align-self:flex-start}.cancel-publish-btn:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80}.cancel-publish-btn:disabled{opacity:.6;cursor:not-allowed}.scheduling-form{display:flex;flex-direction:column;gap:12px;padding:12px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb}.form-label{font-size:.85rem;font-weight:500;color:#374151;margin-bottom:4px}.city-select,.datetime-input{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.85rem;background:#fff;transition:border-color .2s ease}.city-select:focus,.datetime-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.schedule-publish-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;padding:10px 16px;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;margin-top:8px}.schedule-publish-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #8b5cf64d}.schedule-publish-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.publishing-unavailable{font-size:.85rem;color:#6b7280;text-align:center;padding:12px;background:#f9fafb;border-radius:6px;font-style:italic}.success-message{background:#10b981;color:#fff;padding:8px 12px;border-radius:6px;font-size:.8rem;text-align:center;margin-top:8px}.cities-checkbox-container{max-height:200px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:6px;background:#fff;margin-top:8px}.cities-checkbox-container:empty{border:none;background:none}.city-checkbox-option{display:flex;align-items:center;padding:12px 16px;margin:0;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:background-color .15s ease}.city-checkbox-option:last-child{border-bottom:none}.city-checkbox-option:hover{background-color:#f8fafc}.city-checkbox{margin:0 12px 0 0;cursor:pointer;width:16px;height:16px;accent-color:#3b82f6;flex-shrink:0}.city-name{font-size:.9rem;color:#374151;font-weight:500;line-height:1.4}.city-checkbox-option input:checked+.city-name{color:#3b82f6;font-weight:600}.select-all-option{display:flex;align-items:center;padding:10px 0;margin:8px 0 0;cursor:pointer;font-weight:600;color:#374151}.select-all-checkbox{margin:0 12px 0 0;cursor:pointer;width:16px;height:16px;accent-color:#3b82f6;flex-shrink:0}@media (max-width: 768px){.treasure-list{grid-template-columns:1fr;gap:16px}.treasure-card{margin:0}.treasure-header{padding:16px 20px 12px}.treasure-content{padding:16px 20px 20px}.price{font-size:1.75rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:#374151;background-color:#f8fafc;font-size:16px}.container{max-width:1200px;margin:0 auto;padding:24px}header{text-align:center;margin-bottom:32px;padding:48px 32px;background:#fff;color:#1f2937;border-radius:16px;box-shadow:0 1px 3px #0000000d;border:1px solid #e5e7eb}header h1{font-size:2.25rem;margin-bottom:8px;font-weight:700}header p{font-size:1.125rem;color:#6b7280}.auth-form{max-width:400px;margin:0 auto;background:#fff;padding:48px;border-radius:16px;box-shadow:0 1px 3px #0000000d;border:1px solid #e5e7eb}.auth-form h2{text-align:center;margin-bottom:8px;color:#1f2937;font-weight:700;font-size:1.5rem}.auth-form p{text-align:center;margin-bottom:32px;color:#6b7280;font-size:.875rem}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#374151;font-size:.875rem}.form-group input{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:16px;transition:all .2s ease;background-color:#fff}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}button{width:100%;padding:12px 24px;background:#1f2937;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease}button:hover{background:#111827;transform:translateY(-1px)}button:active{transform:translateY(0)}.error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-top:16px;text-align:center;font-size:.875rem}.dashboard{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000000d;border:1px solid #e5e7eb;overflow:hidden}.dashboard-header{background:#fff;color:#1f2937;padding:32px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e5e7eb}.dashboard-header h2{margin:0;font-weight:700;font-size:1.5rem}.dashboard-header p{margin:4px 0 0;color:#6b7280;font-size:.875rem}.dashboard-header button{width:auto;padding:8px 16px;background:#f3f4f6;color:#374151;border:1px solid #d1d5db;font-size:.875rem;margin-left:8px}.dashboard-header .header-actions{display:flex;align-items:center;gap:8px}.dashboard-header .refresh-btn{background:#3b82f6;color:#fff;border:1px solid #2563eb}.dashboard-header .refresh-btn:hover:not(:disabled){background:#2563eb}.dashboard-header .refresh-btn:disabled{opacity:.7;cursor:not-allowed}.dashboard-header button:hover{background:#e5e7eb;transform:none}.dashboard-content{padding:32px}.welcome-message h3{color:#1f2937;margin-bottom:16px;font-size:1.25rem;font-weight:600}.welcome-message p{margin-bottom:16px;color:#6b7280;line-height:1.6}.welcome-message ul{margin:16px 0;color:#6b7280;padding-left:20px}.welcome-message li{margin-bottom:8px}@media (max-width: 768px){.container{padding:16px}header{padding:32px 24px}header h1{font-size:1.875rem}.auth-form{padding:32px 24px}.dashboard-header{flex-direction:column;text-align:center;gap:16px;padding:24px}.dashboard-content{padding:24px}}
