@import "https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;400;500;700;900&family=Outfit:wght@300;400;500;600;700&display=swap";
*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--pink-50:#fdf2f8;--pink-100:#fce7f3;--pink-200:#fbcfe8;--pink-300:#f9a8d4;--pink-400:#f472b6;--pink-500:#ec4899;--pink-600:#db2777;--pink-700:#be185d;--purple-50:#faf5ff;--purple-100:#f3e8ff;--purple-200:#e9d5ff;--purple-300:#d8b4fe;--purple-400:#c084fc;--purple-500:#a855f7;--gray-50:#fafafa;--gray-100:#f4f4f5;--gray-200:#e4e4e7;--gray-300:#d4d4d8;--gray-400:#a1a1aa;--gray-500:#71717a;--gray-600:#52525b;--gray-700:#3f3f46;--gray-800:#27272a;--gray-900:#18181b;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 30px #0000001f;--shadow-xl:0 20px 60px #00000026;--gradient-primary:linear-gradient(135deg, var(--pink-400), var(--purple-400));--gradient-hero:linear-gradient(135deg, #fdf2f8 0%, #f3e8ff 50%, #fce7f3 100%);--font-sans:"Noto Sans TC", "Outfit", system-ui, sans-serif;--transition:.3s cubic-bezier(.4, 0, .2, 1)}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--gray-50);color:var(--gray-800);min-height:100vh;line-height:1.6}.navbar{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--gray-200);background:#ffffffd9;justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex;position:sticky;top:0}.navbar-brand{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:8px;font-size:1.4rem;font-weight:700;text-decoration:none;display:flex}.navbar-links{align-items:center;gap:1.5rem;display:flex}.navbar-links a{color:var(--gray-600);transition:var(--transition);font-size:.9rem;font-weight:500;text-decoration:none}.navbar-links a:hover{color:var(--pink-500)}.hero{background:var(--gradient-hero);text-align:center;padding:4rem 2rem;position:relative;overflow:hidden}.hero:before{content:"";background:radial-gradient(circle,#f472b626 0%,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;top:-50%;right:-20%}.hero:after{content:"";background:radial-gradient(circle,#c084fc1f 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-30%;left:-10%}.hero-content{z-index:1;max-width:700px;margin:0 auto;position:relative}.hero h1{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:1rem;font-size:2.5rem;font-weight:900}.hero p{color:var(--gray-600);max-width:500px;margin:0 auto 2rem;font-size:1.1rem}.btn{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);font-size:.9rem;font-weight:600;font-family:var(--font-sans);border:none;justify-content:center;align-items:center;gap:8px;padding:10px 24px;text-decoration:none;display:inline-flex}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 15px #ec48994d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ec489966}.btn-secondary{color:var(--gray-700);border:1.5px solid var(--gray-200);background:#fff}.btn-secondary:hover{border-color:var(--pink-300);color:var(--pink-500)}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:14px 32px;font-size:1rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-100);transition:var(--transition);background:#fff;overflow:hidden}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-image{aspect-ratio:1;background:#fafafa;justify-content:center;align-items:center;width:100%;font-size:3rem;display:flex;overflow:hidden}.card-image img{object-fit:contain;width:100%;height:100%}.card-body{padding:1.2rem}.card-title{color:var(--gray-800);margin-bottom:.4rem;font-size:1rem;font-weight:700}.card-desc{color:var(--gray-500);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.8rem;font-size:.85rem;display:-webkit-box;overflow:hidden}.card-price{color:var(--pink-600);font-size:1.1rem;font-weight:700}.card-price-jpy{color:var(--gray-400);margin-left:8px;font-size:.8rem;font-weight:400}.grid{gap:1.5rem;display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}@media (max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.section{max-width:1200px;margin:0 auto;padding:3rem 2rem}.section-title{color:var(--gray-800);margin-bottom:.5rem;font-size:1.6rem;font-weight:700}.section-subtitle{color:var(--gray-500);margin-bottom:2rem}.badge{border-radius:20px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-block}.badge-open{color:#065f46;background:#d1fae5}.badge-closed{color:#991b1b;background:#fee2e2}.badge-completed{color:#3730a3;background:#e0e7ff}.badge-category{background:var(--pink-100);color:var(--pink-700)}.groupbuy-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--gray-100);transition:var(--transition);background:#fff;padding:2rem}.groupbuy-card:hover{box-shadow:var(--shadow-lg)}.groupbuy-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.groupbuy-title{font-size:1.3rem;font-weight:700}.groupbuy-desc{color:var(--gray-500);margin-bottom:1.5rem;font-size:.9rem}.groupbuy-stats{gap:2rem;margin-bottom:1.5rem;display:flex}.groupbuy-stat{text-align:center}.groupbuy-stat-value{color:var(--pink-500);font-size:1.5rem;font-weight:700}.groupbuy-stat-label{color:var(--gray-400);font-size:.8rem}.countdown{justify-content:center;gap:.5rem;display:flex}.countdown-item{background:var(--gray-900);color:#fff;border-radius:var(--radius-sm);text-align:center;min-width:48px;padding:8px 12px}.countdown-value{font-family:Outfit,monospace;font-size:1.2rem;font-weight:700}.countdown-label{color:var(--gray-400);font-size:.65rem}.progress{background:var(--gray-200);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:var(--gradient-primary);border-radius:4px;height:100%;transition:width 1s}.form-group{margin-bottom:1.2rem}.form-label{color:var(--gray-700);margin-bottom:.4rem;font-size:.85rem;font-weight:600;display:block}.form-input,.form-select,.form-textarea{border:1.5px solid var(--gray-200);border-radius:var(--radius-md);width:100%;font-size:.9rem;font-family:var(--font-sans);transition:var(--transition);color:var(--gray-800);background:#fff;padding:10px 14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--pink-400);outline:none;box-shadow:0 0 0 3px #f472b626}.form-textarea{resize:vertical;min-height:80px}.form-error{color:var(--danger);margin-top:.3rem;font-size:.8rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-xl);width:100%;max-width:600px;max-height:90vh;box-shadow:var(--shadow-xl);background:#fff;animation:.3s modalIn;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 0;display:flex}.modal-title{font-size:1.2rem;font-weight:700}.modal-close{cursor:pointer;color:var(--gray-400);transition:var(--transition);background:0 0;border:none;font-size:1.5rem}.modal-close:hover{color:var(--gray-800)}.modal-body{padding:1.5rem}.modal-footer{justify-content:flex-end;gap:.8rem;padding:0 1.5rem 1.5rem;display:flex}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.table-container{border-radius:var(--radius-lg);border:1px solid var(--gray-200);overflow-x:auto}table{border-collapse:collapse;background:#fff;width:100%}th{background:var(--gray-50);text-align:left;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--gray-200);padding:12px 16px;font-size:.8rem;font-weight:600}td{border-bottom:1px solid var(--gray-100);padding:12px 16px;font-size:.9rem}tr:hover td{background:var(--pink-50)}.admin-layout{min-height:100vh;display:flex}.admin-sidebar{background:var(--gray-900);color:#fff;flex-shrink:0;align-self:flex-start;width:250px;max-height:100vh;padding:1.5rem;position:sticky;top:0;overflow-y:auto}.admin-sidebar-title{border-bottom:1px solid var(--gray-700);margin-bottom:2rem;padding-bottom:1rem;font-size:1.1rem;font-weight:700}.admin-sidebar-title a{color:#fff;text-decoration:none}.admin-nav a{color:var(--gray-400);border-radius:var(--radius-sm);transition:var(--transition);align-items:center;gap:10px;margin-bottom:4px;padding:10px 14px;font-size:.9rem;text-decoration:none;display:flex}.admin-nav a:hover,.admin-nav a.active{background:var(--gray-800);color:#fff}.admin-main{flex:1;min-width:0;padding:2rem;overflow-y:auto}.admin-mobile-toggle,.admin-sidebar-close,.admin-sidebar-backdrop{display:none}.admin-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.admin-header h1{font-size:1.5rem;font-weight:700}.stat-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-100);background:#fff;padding:1.5rem}.stat-card-value{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:2rem;font-weight:700}.stat-card-label{color:var(--gray-500);margin-top:.3rem;font-size:.85rem}.qty-control{border:1.5px solid var(--gray-200);border-radius:var(--radius-md);align-items:center;gap:0;width:fit-content;display:flex;overflow:hidden}.qty-btn{background:var(--gray-50);cursor:pointer;width:36px;height:36px;color:var(--gray-600);transition:var(--transition);border:none;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.qty-btn:hover:not(:disabled){background:var(--pink-100);color:var(--pink-600)}.qty-btn:disabled{opacity:.4;cursor:not-allowed}.qty-value{text-align:center;background:#fff;border:none;width:40px;font-size:.9rem;font-weight:600}.lookup-box{border-radius:var(--radius-xl);max-width:500px;box-shadow:var(--shadow-lg);background:#fff;margin:0 auto;padding:2.5rem}.toast{background:var(--gray-900);color:#fff;border-radius:var(--radius-md);z-index:300;box-shadow:var(--shadow-lg);padding:12px 20px;font-size:.9rem;animation:.3s toastIn,.3s 2.7s forwards toastOut;position:fixed;bottom:2rem;right:2rem}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0;transform:translateY(20px)}}.footer{background:var(--gray-900);color:var(--gray-400);text-align:center;margin-top:4rem;padding:2rem;font-size:.85rem}.footer a{color:var(--pink-400);text-decoration:none}.footer .social-link{color:var(--gray-300);transition:var(--transition)}.footer .social-link:hover{color:#fff;transform:translateY(-2px)}.spinner{border:3px solid var(--gray-200);border-top-color:var(--pink-500);border-radius:50%;width:32px;height:32px;margin:2rem auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{border-radius:var(--radius-md);background:linear-gradient(90deg,#f4f4f5 25%,#e4e4e7 50%,#f4f4f5 75%) 0 0/200% 100%;animation:1.4s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-100);background:#fff;margin-bottom:1rem;padding:1.2rem}.skeleton-line{height:14px;margin-bottom:10px}.empty-state{text-align:center;color:var(--gray-400);padding:4rem 2rem}.empty-state-icon{margin-bottom:1rem;font-size:3rem}.empty-state-text{font-size:1rem}.checkbox-row{border-radius:var(--radius-md);transition:var(--transition);cursor:pointer;align-items:center;gap:12px;padding:12px;display:flex}.checkbox-row:hover{background:var(--pink-50)}.checkbox-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--pink-500)}@media (max-width:768px){.navbar{padding:0 1rem}.hero h1{font-size:1.8rem}.section{padding:2rem 1rem}.grid-4{grid-template-columns:repeat(2,1fr);gap:.7rem}.card-body{padding:.7rem}.card-title{font-size:.9rem}.card-desc{margin-bottom:.5rem;font-size:.78rem}.card-price{font-size:1rem}.admin-layout{flex-direction:column}.admin-mobile-toggle{z-index:50;background:var(--gray-900);color:#fff;cursor:pointer;text-align:left;border:none;align-items:center;gap:.5rem;width:100%;padding:.7rem 1rem;font-size:.95rem;font-weight:600;display:flex;position:sticky;top:0}.admin-sidebar{z-index:110;width:260px;max-width:80vw;height:100vh;max-height:100vh;transition:transform .25s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.admin-sidebar.admin-sidebar-open{transform:translate(0)}.admin-sidebar-backdrop{z-index:100;background:#00000080;display:block;position:fixed;inset:0}.admin-sidebar-close{color:#fff;cursor:pointer;background:0 0;border:1px solid #3f3f46;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;display:flex;position:absolute;top:.7rem;right:.7rem}.admin-main{padding:1rem}.groupbuy-stats{flex-wrap:wrap;gap:1rem}.modal{margin:1rem}}
