:root{--color-primary:#1a1a1a;--color-accent:#c2185b;--color-accent-light:#f08db4;--color-accent-deep:#8b1a5c;--color-bg:#fafafa;--color-surface:#fff;--color-text:#2d2d2d;--color-text-light:#6b6b6b;--color-border:#e0e0e0;--color-success:#2e7d32;--color-error:#c62828;--font-heading:"Playfair Display","Cormorant Garamond",serif;--font-body:"Inter","Noto Sans",sans-serif;--font-size-h1:3rem;--font-size-h2:2rem;--font-size-h3:1.5rem;--font-size-h4:1.125rem;--font-size-body:1rem;--font-size-caption:0.8125rem;--space-xs:0.5rem;--space-sm:0.75rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius-sm:6px;--radius-md:12px;--radius-lg:20px;--radius-full:50%;--shadow-card:0 2px 12px #0000000f;--shadow-card-hover:0 8px 24px #0000001f;--shadow-button:0 4px 12px #c2185b59;--transition-fast:0.2s ease;--transition-normal:0.3s ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background-color:#fafafa;background-color:var(--color-bg);color:#2d2d2d;color:var(--color-text);font-family:Inter,Noto Sans,sans-serif;font-family:var(--font-body);font-size:1rem;font-size:var(--font-size-body);line-height:1.6}h1,h2,h3,h4,h5{color:#1a1a1a;color:var(--color-primary);font-family:Playfair Display,Cormorant Garamond,serif;font-family:var(--font-heading);font-weight:600;line-height:1.3}h1{font-size:3rem;font-size:var(--font-size-h1)}h2{font-size:2rem;font-size:var(--font-size-h2)}h3{font-size:1.5rem;font-size:var(--font-size-h3)}h4{font-size:1.125rem;font-size:var(--font-size-h4)}a{color:#c2185b;color:var(--color-accent);text-decoration:none;transition:color .2s ease;transition:color var(--transition-fast)}a:hover{color:#f08db4;color:var(--color-accent-light)}img{display:block;height:auto;max-width:100%}.btn{align-items:center;border:2px solid #0000;border-radius:6px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--font-size-body);font-weight:500;gap:.5rem;gap:var(--space-xs);justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease;transition:all var(--transition-fast)}.btn-primary{background-color:#c2185b;background-color:var(--color-accent);border-color:#c2185b;border-color:var(--color-accent);color:#fff}.btn-primary:hover{background-color:#f08db4;background-color:var(--color-accent-light);border-color:#f08db4;border-color:var(--color-accent-light);box-shadow:0 4px 12px #c2185b59;box-shadow:var(--shadow-button);color:#fff}.btn-secondary{background-color:initial;border-color:#c2185b;border-color:var(--color-accent);color:#c2185b;color:var(--color-accent)}.btn-secondary:hover{background-color:#c2185b;background-color:var(--color-accent);color:#fff}.btn-ghost{background-color:initial;border-color:#fff;color:#fff}.btn-ghost:hover{background-color:#fff;color:#1a1a1a;color:var(--color-primary)}.btn:disabled{cursor:not-allowed;opacity:.5}.card{background:#fff;background:var(--color-surface);border-radius:12px;border-radius:var(--radius-md);box-shadow:0 2px 12px #0000000f;box-shadow:var(--shadow-card);overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.card:hover{box-shadow:0 8px 24px #0000001f;box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.container{margin:0 auto;max-width:1280px;padding:0 1.5rem;padding:0 var(--space-lg)}@media (max-width:768px){:root{--font-size-h1:2.25rem;--font-size-h2:1.75rem;--font-size-h3:1.25rem}}.toast-container{left:50%;pointer-events:none;position:fixed;top:20px;transform:translateX(-50%);z-index:9999}.toast{align-items:center;animation:toast-slide-in .3s ease-out;border-radius:8px;box-shadow:0 4px 12px #00000026;cursor:pointer;display:flex;gap:10px;max-width:90%;min-width:200px;padding:14px 20px;pointer-events:auto;width:max-content}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.toast-icon{flex-shrink:0;font-size:18px}.toast-message{font-size:14px;line-height:1.4;word-break:break-word}.toast-success{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.toast-error{background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff}.toast-warning{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.toast-info{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff}@media (max-width:768px){.toast{min-width:250px;padding:12px 16px}}.register-page{align-items:center;display:flex;justify-content:center;min-height:80vh;padding:40px 20px}.register-card{background:#fff;border-radius:12px;box-shadow:0 4px 24px #00000014;max-width:420px;padding:40px;width:100%}.register-card h3{color:var(--color-primary);font-size:1.5rem;margin:0 0 24px;text-align:center}.form-group{margin-bottom:16px}.form-group label{color:var(--color-text);font-size:.9rem;font-weight:500;margin-bottom:6px}.form-group input,.form-group textarea{box-sizing:border-box;font-size:.95rem;padding:10px 12px;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #c2185b1a}.btn-block{font-size:1rem;margin-top:8px;padding:12px;width:100%}.register-footer{color:var(--color-text-light);font-size:.9rem;margin-top:20px;text-align:center}.register-footer p{margin:8px 0}.request-invite{color:var(--color-text-light);font-size:.85rem}.request-invite .link-primary{color:var(--color-accent);cursor:pointer;font-weight:600;text-decoration:none}.request-invite .link-primary:hover{text-decoration:underline}.modal-overlay{animation:fadeIn .2s ease;inset:0;padding:20px}.modal-content{animation:slideUp .3s ease;background:#fff;border-radius:12px;box-shadow:0 8px 40px #0003;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{padding:20px 24px}.modal-header h3{color:var(--color-primary);font-size:1.2rem}.modal-close{background:none;border:none;color:#999;cursor:pointer;font-size:1.5rem;line-height:1;padding:0}.modal-close:hover{color:#333}.modal-body{padding:24px}.modal-desc{color:var(--color-text-light);font-size:.9rem;line-height:1.5;margin:0 0 20px}@media (max-width:480px){.register-card{padding:24px}.modal-content{margin:10px}.modal-body{padding:16px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.materials-page{padding:var(--space-xl) 0}.materials-header{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:space-between;margin-bottom:var(--space-lg)}.materials-header h2{font-size:var(--font-size-h2)}.quota-badge{background:var(--color-accent);border-radius:20px;color:#fff;font-size:var(--font-size-caption);font-weight:500;padding:.3rem 1rem}.quota-badge.quota-low{animation:pulse 2s infinite;background:var(--color-error)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.search-bar{margin-bottom:var(--space-md)}.search-bar input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:var(--font-size-body);max-width:400px;padding:.6rem 1rem;transition:border-color var(--transition-fast);width:100%}.search-bar input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #c8a45c1a;outline:none}.search-bar input::placeholder{color:var(--color-text-light)}.tab{background:var(--color-surface);border:1px solid var(--color-border);border-radius:20px;color:var(--color-text);cursor:pointer;font-size:var(--font-size-body);padding:.5rem 1.5rem;transition:all var(--transition-fast)}.tab:hover{color:var(--color-accent)}.tab.active,.tab:hover{border-color:var(--color-accent)}.tab.active{background:var(--color-accent);color:#fff}.material-grid{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.material-card{display:flex;flex-direction:column}.material-img{aspect-ratio:1/1;background:#f0f0f0;cursor:pointer;overflow:hidden;position:relative;width:100%}.material-img img{height:100%;object-fit:cover;transition:transform var(--transition-normal);width:100%}.material-card:hover .material-img img{transform:scale(1.05)}.material-info{display:flex;flex:1 1;flex-direction:column;padding:var(--space-md)}.material-title{color:var(--color-text);font-size:var(--font-size-h4);font-weight:500;line-height:1.4;margin-bottom:var(--space-xs)}.material-meta{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-bottom:var(--space-sm)}.tag{background:var(--color-bg);border-radius:var(--radius-sm);color:var(--color-text-light);font-size:var(--font-size-caption);font-weight:500;padding:3px 10px}.download-btn{margin-top:auto;width:100%}.download-btn:disabled{cursor:not-allowed;opacity:.5}.skeleton{pointer-events:none}.skeleton-img{animation:shimmer 1.5s infinite;aspect-ratio:1/1;background:linear-gradient(90deg,#eee 25%,#f5f5f5 50%,#eee 75%);background-size:200% 100%;width:100%}.skeleton-text{height:1rem;margin:.8rem}.skeleton-tag,.skeleton-text{background:#eee;border-radius:4px}.skeleton-tag{height:.8rem;margin:0 .8rem .8rem;width:40%}.pagination button{color:var(--color-text);font-size:var(--font-size-body);transition:all var(--transition-fast)}.pagination button:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.pagination span{color:var(--color-text-light);font-size:var(--font-size-caption)}.error-banner{color:var(--color-error);padding:var(--space-xl)}.empty-state,.error-banner{background:var(--color-surface);border-radius:var(--radius-md);text-align:center}.empty-state{color:var(--color-text-light);padding:var(--space-3xl)}@media (max-width:768px){.materials-header{align-items:flex-start;flex-direction:column}.material-grid{gap:var(--space-md);grid-template-columns:repeat(2,1fr)}.category-tabs{gap:var(--space-xs)}.tab{font-size:.9rem;padding:.4rem 1rem}}@media (max-width:480px){.material-grid{grid-template-columns:1fr}.search-bar input{max-width:100%}.pagination{flex-wrap:wrap}}.carousel-container{background:#f0f0f0;border-radius:var(--radius-md);box-shadow:var(--shadow-card);margin:0 auto;max-width:1200px;overflow:hidden;position:relative;width:100%}.carousel-slide{padding-top:40%;position:relative;width:100%}.carousel-item{align-items:flex-end;background-position:50%;background-size:cover;cursor:pointer;display:flex;height:100%;justify-content:center;left:0;opacity:0;position:absolute;top:0;transition:opacity .5s ease;width:100%}.carousel-item.active{opacity:1}.carousel-caption{align-items:center;background:linear-gradient(#0000,#000000b3);color:#fff;display:flex;justify-content:space-between;padding:var(--space-xl) var(--space-lg);width:100%}.carousel-caption h3{color:#fff;font-size:var(--font-size-h3);font-weight:600;text-shadow:1px 1px 4px #000c}.carousel-link-hint{font-size:1.5rem;opacity:.9}.carousel-dots{bottom:var(--space-md);display:flex;gap:var(--space-xs);left:50%;position:absolute;transform:translateX(-50%);z-index:10}.dot{background:#ffffff80;border:none;border-radius:50%;cursor:pointer;height:10px;padding:0;transition:background var(--transition-fast);width:10px}.dot.active{background:var(--color-accent);transform:scale(1.2)}.dot:hover{background:#fffc}.carousel-arrow{background:#0006;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:2rem;line-height:1;padding:.5rem .8rem;position:absolute;top:50%;transform:translateY(-50%);transition:background var(--transition-fast);z-index:10}.carousel-arrow:hover{background:#000000b3}.carousel-arrow.left{left:var(--space-md)}.carousel-arrow.right{right:var(--space-md)}.carousel-skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#eee 25%,#f5f5f5 50%,#eee 75%);background-size:200% 100%;border-radius:var(--radius-md);padding-top:40%;width:100%}@media (max-width:768px){.carousel-slide{padding-top:55%}.carousel-caption h3{font-size:var(--font-size-h4)}.carousel-arrow{font-size:1.5rem;padding:.3rem .5rem}.carousel-arrow.left{left:var(--space-sm)}.carousel-arrow.right{right:var(--space-sm)}}@media (max-width:480px){.carousel-slide{padding-top:60%}.carousel-caption{padding:var(--space-md)}.carousel-caption h3{font-size:1rem}.dot{height:8px;width:8px}}.hero{background:linear-gradient(135deg,#0a0a0a,#1a1a1a 40%,#2d0a1a 70%,#1a1a1a);justify-content:center;min-height:80vh;overflow:hidden;position:relative}.hero,.hero__overlay{align-items:center;display:flex;width:100%}.hero__overlay{height:100%}.hero__content{color:#fff;padding:var(--space-2xl) 0;text-align:center}.hero__brand{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#c2185b,#e91e8a 30%,#f48fb1 70%,#c2185b);background-clip:text;-webkit-background-clip:text;filter:drop-shadow(2px 2px 8px rgba(0,0,0,.7));font-family:var(--font-heading);font-size:4rem;font-weight:700;margin-bottom:var(--space-md)}.hero__tagline{color:#ffffffe6;font-size:1.5rem;font-weight:300;margin:var(--space-md) 0 var(--space-xl)}.hero__actions{display:flex;flex-wrap:wrap;gap:var(--space-md);justify-content:center}.value-props{padding:var(--space-3xl) 0}.props-grid{grid-gap:var(--space-xl);display:grid;gap:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));text-align:center}.props-item{padding:var(--space-lg)}.props-item .props-icon{font-size:3rem;margin-bottom:var(--space-sm)}.props-item h4{color:var(--color-primary);font-size:var(--font-size-h3);margin-bottom:var(--space-xs)}.props-item p{color:var(--color-text-light);line-height:1.6}.categories{padding:0 0 var(--space-3xl)}.categories h2{font-size:var(--font-size-h2);margin-bottom:var(--space-xl);text-align:center}.categories-grid{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.category-card{align-items:flex-end;background:linear-gradient(135deg,#1a1a1a,#3d3d3d);color:#fff;display:flex;font-size:var(--font-size-h3);height:250px;padding:var(--space-md);position:relative;text-decoration:none}.category-img{background-position:50%;background-size:cover;filter:brightness(.7);inset:0;position:absolute;transition:filter var(--transition-normal)}.category-card:hover .category-img{filter:brightness(.5)}.category-card h3{color:#fff;font-weight:600;position:relative;z-index:1}.activities-section{padding:var(--space-2xl) 0}.activities-section h2{font-size:var(--font-size-h2);margin-bottom:var(--space-lg);text-align:center}.featured-products{padding:var(--space-2xl) 0}.featured-products h2{font-size:var(--font-size-h2);margin-bottom:var(--space-lg);text-align:center}.product-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.product-card{text-decoration:none}.product-card__img{aspect-ratio:1;background:#f0f0f0;overflow:hidden;width:100%}.product-card__img img{height:100%;object-fit:cover;transition:transform var(--transition-normal);width:100%}.product-card:hover .product-card__img img{transform:scale(1.05)}.product-card__info{padding:var(--space-md);text-align:center}.product-card__info h4{color:var(--color-text);font-size:var(--font-size-h4);margin-bottom:var(--space-xs)}.badge--member{background:var(--color-accent);border-radius:var(--radius-sm);color:#fff;display:inline-block;font-size:var(--font-size-caption);font-weight:500;padding:4px 12px}.section-footer{margin-top:var(--space-xl);text-align:center}.testimonials{background:var(--color-surface);padding:var(--space-3xl) 0}.trust-banner{display:flex;flex-wrap:wrap;gap:var(--space-2xl);justify-content:center;margin-bottom:var(--space-2xl);padding:var(--space-xl) 0}.trust-item{min-width:150px;text-align:center}.trust-number{color:var(--color-accent);display:block;font-size:var(--font-size-h2);font-weight:700;margin-bottom:var(--space-xs)}.trust-label{color:var(--color-text-light);display:block;font-size:var(--font-size-caption)}.partner-logos{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-xl);justify-content:center;opacity:.7;padding:var(--space-lg) 0}.partner-logos img{filter:grayscale(100%);height:40px;transition:opacity var(--transition-fast);width:auto}.partner-logos img:hover{filter:grayscale(0);opacity:1}.cta-bottom{background:var(--color-primary);color:#fff;padding:var(--space-3xl) 0;text-align:center}.cta-bottom h2{color:var(--color-accent);font-size:var(--font-size-h2);margin-bottom:var(--space-lg)}@media (max-width:768px){.hero__brand{font-size:2.5rem}.hero__tagline{font-size:1.2rem}.hero{min-height:60vh}.categories-grid{grid-template-columns:1fr}.product-grid{grid-template-columns:repeat(2,1fr)}.trust-banner{gap:var(--space-lg)}.trust-item{min-width:120px}}@media (max-width:480px){.product-grid{grid-template-columns:1fr}.hero__actions{flex-direction:column;padding:0 var(--space-md);width:100%}.hero__actions .btn{width:100%}}.admin-points-page{padding:20px}.adjust-form-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:24px}.adjust-form{max-width:600px}.adjust-form .form-group{margin-bottom:16px}.adjust-form label{color:#333;display:block;font-weight:600;margin-bottom:6px}.adjust-form input,.adjust-form select,.adjust-form textarea{border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:14px;padding:10px;width:100%}.adjust-form input:focus,.adjust-form select:focus,.adjust-form textarea:focus{border-color:#c2185b;box-shadow:0 0 0 2px #c2185b1a;outline:none}.form-hint{color:#999;display:block;font-size:12px;margin-top:4px}.submit-btn{background:linear-gradient(135deg,#c2185b,#e91e8a);border-radius:6px;cursor:pointer;font-size:16px;padding:12px 24px;transition:opacity .2s;width:100%}.submit-btn:disabled{opacity:.6}.submit-btn:hover:not(:disabled){opacity:.9}.alert{border-radius:6px;font-size:14px;margin-bottom:16px;padding:12px 16px}.alert-success{background:#e8f5e9;border:1px solid #a5d6a7;color:#2e7d32}.alert-error{background:#ffebee;border:1px solid #ef9a9a;color:#c62828}.adjust-logs-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:24px}.logs-table td,.logs-table th{border-bottom:1px solid #f0f0f0;padding:10px 12px}.logs-table th{background:#f8f8f8;color:#555}.no-data{padding:24px!important}.points-add{color:#2e7d32}.points-subtract{color:#c62828}.admin-panel{padding:var(--space-xl) 0}.admin-panel h2{color:var(--color-primary);margin-bottom:var(--space-lg)}.tab-bar{border-bottom:2px solid var(--color-border);display:flex;gap:var(--space-sm);margin-bottom:var(--space-xl)}.tab-btn{background:none;border:none;border-bottom:2px solid #0000;color:var(--color-text-light);cursor:pointer;font-size:var(--font-size-body);font-weight:500;margin-bottom:-2px;padding:.75rem 1.5rem;transition:all var(--transition-fast)}.tab-btn.active{border-bottom-color:var(--color-accent);color:var(--color-accent)}.tab-content{min-height:400px}.admin-loading{color:var(--color-text-light);padding:var(--space-2xl);text-align:center}.feedback-page{padding:var(--space-xl) 0}.feedback-header{margin-bottom:var(--space-2xl);text-align:center}.feedback-header h2{color:var(--color-primary)}.subtitle{margin-top:var(--space-xs)}.feedback-layout{grid-gap:var(--space-2xl);align-items:start;display:grid;gap:var(--space-2xl);grid-template-columns:1fr 1.5fr}.feedback-form{padding:var(--space-xl)}.feedback-form h3{margin-bottom:var(--space-md)}.feedback-form textarea{border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:var(--font-size-body);min-height:120px;padding:var(--space-md);resize:vertical;transition:border-color var(--transition-fast);width:100%}.feedback-form textarea:focus{border-color:var(--color-accent);outline:none}.form-actions{flex-wrap:wrap;gap:var(--space-sm);justify-content:space-between;margin-top:var(--space-md)}.checkbox-label,.form-actions{align-items:center;display:flex}.checkbox-label{color:var(--color-text-light);cursor:pointer;font-size:var(--font-size-caption);gap:var(--space-xs)}.success-msg{color:var(--color-success)}.error-msg,.success-msg{font-weight:500;margin-top:var(--space-sm)}.error-msg{color:var(--color-error)}.feedback-list h3{margin-bottom:var(--space-lg)}.feedback-card{margin-bottom:var(--space-md);padding:var(--space-lg)}.feedback-meta{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-sm)}.user{color:var(--color-primary);font-weight:600}.status{background:#f0f0f0;border-radius:10px;font-size:var(--font-size-caption);padding:2px 8px}.status-pending{background:#fff3cd;color:#856404}.status-replied{background:#d4edda;color:#155724}.status-closed{background:#e2e3e5;color:#383d41}.date{color:var(--color-text-light);font-size:var(--font-size-caption);margin-left:auto}.feedback-content{color:var(--color-text);line-height:1.6;margin-bottom:var(--space-sm)}.feedback-reply{background:#f8f8f8;border-left:3px solid var(--color-accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-top:var(--space-sm);padding:var(--space-md)}.reply-label{color:var(--color-accent);display:block;font-size:var(--font-size-caption);font-weight:600;margin-bottom:var(--space-xs)}.feedback-reply p{color:var(--color-text);font-size:var(--font-size-body)}.empty-text,.loading-text{color:var(--color-text-light);padding:var(--space-xl);text-align:center}@media (max-width:768px){.feedback-layout{grid-template-columns:1fr}}.points-shop-page{background:#f5f5f5;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px}.points-header{margin-bottom:30px}.points-card{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 4px 6px #0000001a;display:flex;gap:20px;padding:30px}.points-icon{font-size:60px}.points-info{color:#fff}.points-label{font-size:16px;margin-bottom:8px;opacity:.9}.points-value{font-size:48px;font-weight:700}.gifts-section{margin-bottom:40px}.section-title{border-bottom:2px solid #667eea;color:#333;font-size:24px;margin-bottom:20px;padding-bottom:10px}.gifts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.gift-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:transform .3s,box-shadow .3s}.gift-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.gift-image{background:#f5f5f5;height:200px;overflow:hidden;width:100%}.gift-image img{height:100%;object-fit:cover;width:100%}.gift-info{padding:20px}.gift-name{color:#333;font-size:18px;font-weight:600;margin:0 0 10px}.gift-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#666;display:-webkit-box;font-size:14px;line-height:1.5;margin:0 0 15px;overflow:hidden}.gift-meta{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.gift-points{color:#667eea;font-size:16px;font-weight:600}.points-badge{background:#667eea;border-radius:20px;color:#fff;margin-right:4px;padding:4px 12px}.gift-stock{color:#999;font-size:12px}.gift-stock-unlimited{color:#52c41a;font-size:12px}.redeem-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px;transition:opacity .3s;width:100%}.redeem-btn:hover{opacity:.9}.logs-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px}.logs-table-container{overflow-x:auto}.logs-table{border-collapse:collapse;width:100%}.logs-table td,.logs-table th{border-bottom:1px solid #eee;padding:12px;text-align:left}.logs-table th{background:#f9f9f9;color:#333;font-weight:600}.logs-table td{color:#666}.no-data{color:#999;padding:40px!important;text-align:center}.points-add{color:#52c41a!important;font-weight:600}.points-subtract{color:#ff4d4f!important;font-weight:600}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.redeem-modal{background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:20px}.modal-header h3{color:#333;font-size:20px;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:background .3s;width:32px}.close-btn:hover{background:#f5f5f5}.modal-body{padding:20px}.selected-gift{background:#f9f9f9;border-radius:8px;display:flex;gap:15px;margin-bottom:20px;padding:15px}.selected-gift img{border-radius:8px;height:80px;object-fit:cover;width:80px}.gift-details{flex:1 1}.gift-details h4{color:#333;font-size:16px;margin:0 0 10px}.gift-points-display{color:#666;font-size:14px;margin:5px 0}.points-highlight{color:#667eea;font-size:18px;font-weight:600}.current-points{color:#999;font-size:14px;margin:5px 0}.shipping-form h4{color:#333;font-size:16px;margin:0 0 15px}.form-group{margin-bottom:15px}.form-group label{color:#666;display:block;font-size:14px;margin-bottom:5px}.form-group input,.form-group textarea{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:10px;transition:border-color .3s;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.form-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr}.modal-footer{border-top:1px solid #eee;display:flex;gap:10px;padding:20px}.cancel-btn,.submit-btn{border-radius:8px;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px;transition:opacity .3s}.cancel-btn{background:#f5f5f5;border:1px solid #ddd;color:#666}.cancel-btn:hover{opacity:.8}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.submit-btn:hover{opacity:.9}.submit-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.points-card{flex-direction:column;text-align:center}.points-value{font-size:36px}.form-row,.gifts-grid{grid-template-columns:1fr}.logs-table td,.logs-table th{font-size:12px;padding:8px 4px}}.products-page{padding:var(--space-xl) 0}.products-header{margin-bottom:var(--space-xl);text-align:center}.products-header h2{color:var(--color-primary);font-size:var(--font-size-h2);margin-bottom:var(--space-xs)}.subtitle{color:var(--color-text-light);font-size:var(--font-size-body)}.category-tabs{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center;margin-bottom:var(--space-xl)}.product-grid{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.product-card{position:relative}.product-img{aspect-ratio:1;background:#f0f0f0;overflow:hidden;width:100%}.product-img img{height:100%;object-fit:cover;transition:transform var(--transition-normal);width:100%}.product-card:hover .product-img img{transform:scale(1.05)}.product-overlay{left:var(--space-sm);position:absolute;top:var(--space-sm)}.member-badge{background:var(--color-accent);border-radius:4px;color:#fff;font-size:var(--font-size-caption);font-weight:500;padding:2px 10px}.product-info{padding:var(--space-md)}.product-info h4{color:var(--color-text);font-size:var(--font-size-h4);margin-bottom:var(--space-xs)}.product-desc{color:var(--color-text-light);font-size:var(--font-size-caption)}.sub-tabs{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:var(--space-md)}.sub-tab{background:var(--color-surface);border:1px solid var(--color-border);border-radius:20px;cursor:pointer;font-size:.8rem;padding:4px 12px;transition:all .2s;white-space:nowrap}.sub-tab:hover{color:var(--color-accent)}.sub-tab.active,.sub-tab:hover{border-color:var(--color-accent)}.sub-tab.active{background:var(--color-accent);color:#fff}.color-tab{min-width:70px;text-align:center}.more-colors{color:var(--color-text-light);font-size:.8rem;padding:4px 8px}.skeleton .skeleton-img{animation:shimmer 1.5s infinite;aspect-ratio:1;background:linear-gradient(90deg,#eee 25%,#f5f5f5 50%,#eee 75%);background-size:200% 100%;width:100%}.skeleton .skeleton-text{background:#eee;border-radius:4px;height:1rem;margin:.8rem}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.pagination{align-items:center;display:flex;gap:var(--space-md);justify-content:center;margin-top:var(--space-2xl)}.pagination button{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;padding:.4rem 1rem}.pagination button:disabled{cursor:not-allowed;opacity:.5}.empty-state,.error-banner{color:var(--color-text-light);padding:var(--space-2xl);text-align:center}.product-detail-page{padding:var(--space-xl) 0}.back-link{color:var(--color-accent);display:inline-block;font-weight:500;margin-bottom:var(--space-lg)}.back-link:hover{text-decoration:underline}.detail-grid{grid-gap:var(--space-2xl);align-items:start;display:grid;gap:var(--space-2xl);grid-template-columns:1fr 1fr}.detail-gallery .main-image{aspect-ratio:1;background:#f0f0f0;border-radius:var(--radius-md);margin-bottom:var(--space-md);overflow:hidden}.main-image img{height:100%;object-fit:cover;width:100%}.thumbnail-list{display:flex;gap:var(--space-sm)}.thumb{background:#f0f0f0;border:2px solid #0000;border-radius:var(--radius-sm);cursor:pointer;height:70px;overflow:hidden;transition:border-color var(--transition-fast);width:70px}.thumb img{height:100%;object-fit:cover;width:100%}.thumb.active{border-color:var(--color-accent)}.detail-info{padding-top:var(--space-md)}.member-exclusive{margin-bottom:var(--space-sm)}.badge-accent{background:var(--color-accent);border-radius:20px;color:#fff;display:inline-block;font-size:var(--font-size-caption);font-weight:600;padding:4px 14px;text-transform:uppercase}.detail-info h1{font-size:var(--font-size-h2);margin:var(--space-sm) 0 var(--space-lg)}.product-specs{border-bottom:1px solid var(--color-border);display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-xl);padding-bottom:var(--space-lg)}.spec-item{color:var(--color-text-light);display:flex;gap:var(--space-xs)}.spec-label{color:var(--color-text);font-weight:500}.product-description h3{font-size:var(--font-size-h4);margin-bottom:var(--space-sm)}.product-description p{color:var(--color-text-light);line-height:1.8;white-space:pre-line}.cta-group{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-top:var(--space-xl)}@media (max-width:768px){.detail-grid{gap:var(--space-lg);grid-template-columns:1fr}.thumbnail-list{justify-content:center}}
/*# sourceMappingURL=main.6d3d8d71.css.map*/