:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--color-bg: #f0ede6;--color-bg-card: #fafaf7;--color-bg-input: #ffffff;--color-bg-subtle: #e9e5dc;--color-bg-jade-tint: #eef5f0;--color-text: #2a2520;--color-text-muted: #8c8278;--color-text-light: #b4aca2;--color-jade: #6a9e79;--color-jade-hover: #568465;--color-jade-light: #9cbfa9;--color-sand: #c4b49e;--color-border: #ddd8cf;--color-border-focus: #6a9e79;--font-display: "Cormorant Garamond", "Noto Serif SC", Georgia, serif;--font-title: "Noto Serif SC", "STSong", "SimSun", serif;--font-body: "Noto Serif SC", "STSong", "SimSun", serif;--font-ui: -apple-system, "Helvetica Neue", "PingFang SC", sans-serif;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1.25rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-card: 0 2px 16px rgba(60, 50, 40, .08), 0 1px 4px rgba(60, 50, 40, .04);--shadow-float: 0 8px 32px rgba(60, 50, 40, .12), 0 2px 8px rgba(60, 50, 40, .06);--font-hero: clamp(1.8rem, 5vw, 3rem);--font-title-resp: clamp(1.3rem, 3.5vw, 2rem);--font-section-resp: clamp(1.1rem, 2.5vw, 1.5rem);--font-body-resp: clamp(.85rem, 2.2vw, .95rem);--spacing-page: clamp(.8rem, 3vw, 2rem);--spacing-card: clamp(.6rem, 2vw, 1.2rem)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--color-bg);color:var(--color-text);font-family:var(--font-body);min-height:100vh;-webkit-text-size-adjust:100%;background-image:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(106,158,121,.07) 0%,transparent 70%)}h1,h2,h3{font-family:var(--font-title);font-weight:500}input,select,textarea{background:var(--color-bg-input);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.7rem .9rem;font-family:var(--font-body);font-size:.95rem;width:100%;outline:none;transition:border-color .2s;-webkit-appearance:none;appearance:none}input:focus,select:focus,textarea:focus{border-color:var(--color-border-focus)}select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238c8278' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .8rem center;padding-right:2.2rem}.fortune-markdown{line-height:2;font-size:.95rem;color:var(--color-text);font-family:var(--font-body);font-weight:300}.fortune-markdown h2{color:var(--color-jade);font-family:var(--font-title);font-size:1.05rem;font-weight:500;letter-spacing:.08em;margin:1.8rem 0 .6rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.fortune-markdown h3{color:var(--color-text);font-family:var(--font-title);font-size:.95rem;font-weight:500;margin:1.2rem 0 .4rem;letter-spacing:.05em}.fortune-markdown strong{color:var(--color-jade);font-weight:600}.fortune-markdown hr{border:none;border-top:1px solid var(--color-border);margin:1.4rem 0}.fortune-markdown blockquote{border-left:2px solid var(--color-jade-light);background:var(--color-bg-jade-tint);margin:1rem 0;padding:.8rem 1rem;border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--color-text-muted);font-style:italic}.fortune-markdown p{margin:.6rem 0}.fortune-markdown ul,.fortune-markdown ol{padding-left:1.4rem;margin:.4rem 0}.fortune-markdown li{margin:.3rem 0}.brand-section{margin-top:2.5rem}.brand-section-title{text-align:center;color:var(--color-text-light);font-family:var(--font-display);font-style:italic;letter-spacing:.15em;font-size:.82rem;margin-bottom:1.2rem}.brand-cards{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.brand-cards .brand-card:last-child:nth-child(odd){grid-column:1 / -1}.brand-card{background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.2rem 1rem;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s;text-align:center;min-height:90px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem}.brand-card:hover,.brand-card:active{border-color:var(--color-jade);box-shadow:0 4px 16px #6a9e791f;transform:translateY(-1px)}.brand-card-icon{font-size:1.25rem}.brand-card-title{color:var(--color-text);font-family:var(--font-title);font-size:.9rem;font-weight:500;letter-spacing:.1em}.brand-card-subtitle{color:var(--color-text-light);font-size:.72rem;font-family:var(--font-ui)}.brand-back-link{margin-top:2rem;border-left:2px solid var(--color-jade-light);padding-left:1rem;color:var(--color-jade);cursor:pointer;transition:color .2s}.brand-back-link:hover{color:var(--color-jade-hover)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:60px;background:var(--color-bg-card);border-top:1px solid var(--color-border);display:flex;align-items:stretch;z-index:100;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.18rem;cursor:pointer;border:none;background:transparent;transition:background .15s;-webkit-tap-highlight-color:transparent}.bottom-nav-item:active{background:var(--color-bg-jade-tint)}.bottom-nav-icon{font-size:1.1rem;line-height:1}.bottom-nav-label{font-size:.68rem;font-family:var(--font-ui);letter-spacing:.02em;color:var(--color-text-light);transition:color .15s}.bottom-nav-item.active .bottom-nav-label{color:var(--color-jade);font-weight:500}.bottom-nav-item.active .bottom-nav-icon{filter:none}.bottom-nav-dot{width:4px;height:4px;border-radius:50%;background:var(--color-jade);margin:0 auto;opacity:0;transition:opacity .15s}.bottom-nav-item.active .bottom-nav-dot{opacity:1}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.page-enter{animation:fadeUp .4s ease both}@keyframes blink{50%{opacity:0}}.hero-page{min-height:100vh;background:url(/images/background-detail-app.jpg) center/cover no-repeat fixed;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-page) 1rem;position:relative;overflow:hidden}.hero-page:before{content:"";position:absolute;inset:0;background:#0000004d;z-index:0}.hero-particles{position:absolute;inset:0;pointer-events:none;z-index:0}.hero-particle{position:absolute;border-radius:50%;animation-timing-function:ease-in-out;animation-iteration-count:infinite;animation-direction:alternate}.hero-particle:nth-child(n+9){display:none}.hero-particle-0{width:4px;height:4px;background:#d4b87a;opacity:.6;animation-name:heroFloat0;animation-duration:20s;animation-delay:0s}.hero-particle-0:nth-child(1){top:8%;left:12%}.hero-particle-0:nth-child(5){top:55%;left:78%}.hero-particle-0:nth-child(9){top:30%;left:45%}.hero-particle-1{width:2px;height:2px;background:#ffffff4d;opacity:.5;animation-name:heroFloat1;animation-duration:28s;animation-delay:-5s}.hero-particle-1:nth-child(2){top:22%;left:68%}.hero-particle-1:nth-child(6){top:70%;left:25%}.hero-particle-1:nth-child(10){top:15%;left:90%}.hero-particle-2{width:6px;height:6px;background:#d4b87a;opacity:.35;animation-name:heroFloat2;animation-duration:35s;animation-delay:-10s}.hero-particle-2:nth-child(3){top:45%;left:8%}.hero-particle-2:nth-child(7){top:82%;left:55%}.hero-particle-2:nth-child(11){top:60%;left:35%}.hero-particle-3{width:3px;height:3px;background:#ffffff4d;opacity:.4;animation-name:heroFloat3;animation-duration:15s;animation-delay:-3s}.hero-particle-3:nth-child(4){top:35%;left:92%}.hero-particle-3:nth-child(8){top:90%;left:15%}.hero-particle-3:nth-child(12){top:75%;left:65%}@keyframes heroFloat0{0%{transform:translateY(0) translate(0)}50%{transform:translateY(-30px) translate(15px)}to{transform:translateY(10px) translate(-10px)}}@keyframes heroFloat1{0%{transform:translateY(0) translate(0)}50%{transform:translateY(20px) translate(-20px)}to{transform:translateY(-15px) translate(10px)}}@keyframes heroFloat2{0%{transform:translateY(0) translate(0)}50%{transform:translateY(-25px) translate(-15px)}to{transform:translateY(20px) translate(20px)}}@keyframes heroFloat3{0%{transform:translateY(0) translate(0)}50%{transform:translateY(15px) translate(25px)}to{transform:translateY(-20px) translate(-5px)}}.hero-title{font-family:"Noto Serif SC",serif;font-size:var(--font-hero);color:#d4b87a;letter-spacing:.15em;font-weight:600;margin:0;position:relative;z-index:1;text-shadow:0 2px 8px rgba(0,0,0,.5)}.hero-subtitle{color:#e0d8cc;font-size:clamp(.8rem,2.5vw,.95rem);text-shadow:0 1px 6px rgba(0,0,0,.5);letter-spacing:.1em;margin-top:.4rem;margin-bottom:1.5rem;position:relative;z-index:1}.hero-cards{width:100%;position:relative;z-index:1}.hero-card{background:#00000059;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(212,184,122,.25);border-radius:12px;padding:1.2rem 1rem;margin:0 auto 1rem;cursor:pointer;text-align:center;transition:border-color .3s,box-shadow .3s}.hero-card:hover{border-color:#d4b87a80;box-shadow:0 0 20px #d4b87a26}.hero-card:focus-visible{outline:2px solid #d4b87a;outline-offset:2px}.hero-card-title{font-size:1rem;color:#f5f0e8;font-family:"Noto Serif SC",serif;letter-spacing:.08em;font-weight:500;margin:0 0 .3rem}.hero-card-desc{color:#b8ad9e;font-size:.78rem;margin:0 0 .8rem;letter-spacing:.05em}.hero-card-btn{background:transparent;border:1px solid #d4b87a;color:#d4b87a;border-radius:6px;padding:.6rem 0;width:100%;font-size:.85rem;letter-spacing:.1em;cursor:pointer;transition:background .3s,color .3s;font-family:inherit}.hero-card-btn:hover{background:#d4b87a;color:#1a1a2e}.hero-arrow{color:#d4b87a;opacity:.5;font-size:1.2rem;margin-top:1.5rem;position:relative;z-index:1;animation:heroBounce 2s ease-in-out infinite}@keyframes heroBounce{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}@media(min-width:480px){.hero-particle:nth-child(n+9){display:block}.hero-card-btn{width:auto;padding:.5rem 1.5rem}.hero-card{padding:1.5rem;max-width:380px}.hero-card-title{font-size:1.1rem}}@media(min-width:768px){.hero-title{letter-spacing:.3em}.hero-subtitle{letter-spacing:.15em;margin-bottom:2.5rem}.hero-cards{max-width:420px}.hero-card{margin-bottom:1.2rem}.hero-arrow{margin-top:2rem}}.admin-root{min-height:100vh;display:flex;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;color:#1a1a1a}.admin-sidebar{width:200px;background:#fff;border-right:1px solid #e0e0e0;display:none;flex-direction:column;padding:0;flex-shrink:0}.admin-sidebar-title{padding:20px 16px;font-size:15px;font-weight:600;border-bottom:1px solid #e0e0e0;color:#333}.admin-nav-item{display:block;padding:12px 16px;color:#555;text-decoration:none;border-left:3px solid transparent;cursor:pointer;background:none;border-top:none;border-right:none;border-bottom:none;width:100%;text-align:left;font-size:14px}.admin-nav-item:hover{background:#f5f5f5;color:#1a1a1a}.admin-nav-item.active{border-left-color:#1a73e8;background:#e8f0fe;color:#1a73e8;font-weight:500}.admin-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.admin-topbar{background:#fff;border-bottom:1px solid #e0e0e0;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;font-size:14px}.admin-content{flex:1;padding:24px;overflow-y:auto}.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #00000014}.admin-table th{background:#f8f8f8;padding:10px 14px;text-align:left;font-weight:500;font-size:13px;color:#555;border-bottom:1px solid #e0e0e0}.admin-table td{padding:10px 14px;border-bottom:1px solid #f0f0f0;vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#fafafa}.admin-form-row{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}.admin-form-row label{font-size:13px;color:#555;font-weight:500}.admin-input{padding:8px 10px;border:1px solid #d0d0d0;border-radius:6px;font-size:14px;outline:none;width:100%;box-sizing:border-box}.admin-input:focus{border-color:#1a73e8;box-shadow:0 0 0 2px #1a73e826}.admin-btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.admin-btn-primary{background:#1a73e8;color:#fff}.admin-btn-primary:hover{background:#1557b0}.admin-btn-danger{background:#d93025;color:#fff}.admin-btn-danger:hover{background:#b3261e}.admin-btn-secondary{background:#f1f3f4;color:#333}.admin-btn-secondary:hover{background:#e8eaed}.admin-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.admin-modal{background:#fff;border-radius:10px;padding:24px;width:95vw;max-width:340px;box-shadow:0 8px 32px #0000002e}@media(min-width:480px){.admin-modal{width:auto;min-width:400px;max-width:600px}}.admin-modal h3{margin:0 0 16px;font-size:16px}.admin-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.admin-page-header h2{margin:0;font-size:18px;font-weight:600}.admin-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500}.admin-badge-admin{background:#e8f0fe;color:#1a73e8}.admin-badge-manager{background:#fce8e6;color:#d93025}.admin-badge-staff{background:#f1f3f4;color:#5f6368}.admin-badge-active{background:#e6f4ea;color:#137333}.admin-badge-inactive{background:#fce8e6;color:#d93025}.admin-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:8px}.admin-root{flex-direction:column}.admin-content{padding:16px 16px 72px}.admin-topbar{padding:10px 12px}.admin-topbar .admin-btn{font-size:12px;padding:6px 10px}.admin-table-wrapper .admin-table{min-width:520px}.admin-mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:56px;background:#fff;border-top:1px solid #e0e0e0;z-index:200}.admin-root:has(.customer-create-page) .admin-mobile-nav{display:none}.admin-mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;cursor:pointer;font-size:11px;color:#888;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,sans-serif;-webkit-tap-highlight-color:transparent}.admin-mobile-nav-item.active{color:#1a73e8}.admin-mobile-nav-item .nav-icon{font-size:18px;line-height:1}@media(min-width:768px){.admin-root{flex-direction:row}.admin-sidebar{display:flex}.admin-main{margin-left:0}.admin-content{padding:24px}.admin-topbar{padding:12px 24px}.admin-topbar .admin-btn{font-size:14px;padding:8px 16px}.admin-mobile-nav{display:none}.admin-table-wrapper .admin-table{min-width:auto}}.admin-detail-card{background:#fff;border-radius:8px;padding:20px;margin-bottom:16px;box-shadow:0 1px 3px #00000014}.admin-detail-card h3{margin:0 0 14px;font-size:15px;font-weight:600;color:#333;border-bottom:1px solid #f0f0f0;padding-bottom:10px}.admin-detail-grid{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:480px){.admin-detail-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}.admin-detail-grid>div{display:flex;flex-direction:column;gap:4px}.admin-detail-label{font-size:12px;color:#888}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.login-container{background:#fff;align-items:flex-start;padding-top:20vh}.login-card{background:#fff;border-radius:0;padding:0 24px;width:100%;max-width:100vw;box-shadow:none}.login-title{margin:0 0 32px;font-size:24px;font-weight:600;color:#1a1a1a;text-align:center}.login-input{margin-bottom:16px;height:48px;font-size:16px}.login-btn{width:100%;padding:10px;height:48px;font-size:16px}@media(min-width:480px){.login-container{background:#f5f5f5;align-items:center;padding-top:0}.login-card{border-radius:12px;padding:36px 32px;width:340px;box-shadow:0 4px 20px #0000001a}.login-title{font-size:20px;margin-bottom:24px}.login-input{margin-bottom:14px;height:auto;font-size:14px}.login-btn{height:auto;font-size:14px}}.customer-create-page{max-width:480px;margin:0 auto;padding:0 16px 120px;overscroll-behavior:none}.customer-create-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.customer-create-back{background:none;border:none;font-size:20px;cursor:pointer;padding:4px;color:#555}.customer-create-header h2{margin:0;font-size:18px;font-weight:600}.customer-create-step{font-size:13px;color:#888;margin-bottom:20px}.customer-create-page .admin-form-row{margin-bottom:18px}.customer-create-page .admin-form-row label{font-size:14px;margin-bottom:6px}.customer-create-page .admin-input{height:48px;font-size:16px;padding:10px 14px;border-radius:8px}.category-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.category-item{display:flex;align-items:center;gap:8px;min-height:44px;padding:8px 10px;font-size:14px;cursor:pointer;border:1px solid #e0e0e0;border-radius:8px;background:#fff;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.category-item.selected{border-color:#1a73e8;background:#e8f0fe;color:#1a73e8}.category-item input[type=checkbox]{width:18px;height:18px;flex-shrink:0}.customer-create-bottom{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e0e0e0;padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));display:flex;gap:12px;justify-content:center;z-index:100}.customer-create-bottom .admin-btn{height:48px;font-size:16px;flex:1;max-width:480px}.customer-create-bottom .btn-skip{background:none;border:none;color:#888;font-size:15px;cursor:pointer;padding:12px 16px;flex:none}.register-page{min-height:100vh;background:var(--color-bg);padding:1rem .8rem 6rem;max-width:none;margin:0;animation:fadeUp .4s ease both}.register-header{font-family:var(--font-title);font-size:1.6rem;font-weight:500;color:var(--color-text);text-align:center;margin-bottom:.5rem;letter-spacing:.15em}.register-hint{text-align:center;color:var(--color-text-muted);font-size:.85rem;margin-bottom:1.8rem;font-family:var(--font-ui)}.register-subtitle{text-align:center;color:var(--color-text-muted);font-size:.95rem;margin-bottom:2rem}.register-form-row{margin-bottom:1.2rem}.register-form-row label{display:block;font-size:.85rem;color:var(--color-text-muted);margin-bottom:.4rem;font-family:var(--font-ui)}.register-input{width:100%;height:48px;padding:0 .9rem;background:var(--color-bg-input, #ffffff);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;color:var(--color-text);font-family:var(--font-body);outline:none;transition:border-color .2s;-webkit-appearance:none;appearance:none}.register-input:focus{border-color:var(--color-border-focus)}.register-input::placeholder{color:var(--color-text-light, #b4aca2)}.register-error{color:#c0392b;font-size:.85rem;margin:.5rem 0;font-family:var(--font-ui)}.register-bottom{position:fixed;bottom:0;left:0;right:0;padding:1rem 1.2rem;padding-bottom:max(1rem,env(safe-area-inset-bottom));background:var(--color-bg);border-top:1px solid var(--color-border);display:flex;gap:.75rem;max-width:420px;margin:0 auto}.register-btn{flex:1;height:48px;background:var(--color-jade);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-family:var(--font-ui);font-weight:500;cursor:pointer;transition:background .2s,opacity .2s}.register-btn:hover{background:var(--color-jade-hover)}.register-btn:disabled{opacity:.5;cursor:not-allowed}.register-btn-secondary{background:transparent;color:var(--color-jade);border:1px solid var(--color-jade)}.register-btn-secondary:hover{background:var(--color-bg-jade-tint, #eef5f0)}.register-success{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding-top:25vh}.register-success .register-btn{width:200px;flex:none;margin-top:2rem}.register-birthday .admin-input{height:48px;font-size:1rem}.sms-overlay{position:fixed;inset:0;background:#2a252080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.sms-modal{background:var(--color-bg-card);border-radius:var(--radius-md);padding:2rem 1.5rem;width:95vw;max-width:340px;position:relative;box-shadow:var(--shadow-float, 0 8px 32px rgba(60,50,40,.12))}.sms-close{position:absolute;top:.8rem;right:.8rem;background:none;border:none;font-size:1.5rem;color:var(--color-text-muted);cursor:pointer;line-height:1}.sms-title{font-family:var(--font-title);font-size:1.2rem;font-weight:500;color:var(--color-text);text-align:center;margin-bottom:.3rem}.sms-subtitle{text-align:center;color:var(--color-text-muted);font-size:.85rem;margin-bottom:1.2rem;font-family:var(--font-ui)}.sms-error{color:#c0392b;font-size:.85rem;text-align:center;margin-bottom:.8rem;font-family:var(--font-ui)}.sms-field{margin-bottom:.5rem}.sms-label{display:block;font-size:.82rem;color:var(--color-text-muted);margin-bottom:.3rem;font-family:var(--font-ui)}.sms-input{width:100%;height:48px;padding:0 .9rem;background:var(--color-bg-input, #ffffff);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1.1rem;color:var(--color-text);text-align:center;letter-spacing:.3em;outline:none;transition:border-color .2s}.sms-input:focus{border-color:var(--color-border-focus)}.sms-btn{width:100%;height:44px;background:var(--color-jade);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-family:var(--font-ui);cursor:pointer;transition:background .2s,opacity .2s}.sms-btn:hover{background:var(--color-jade-hover)}.sms-btn:disabled{opacity:.5;cursor:not-allowed}.sms-btn-secondary{background:transparent;color:var(--color-jade);border:1px solid var(--color-jade)}.sms-btn-secondary:hover{background:var(--color-bg-jade-tint, #eef5f0)}@media(min-width:480px){.register-page{padding:1.5rem 1.2rem 6rem}.sms-modal{width:360px;max-width:90vw}}@media(min-width:768px){.register-page{padding:2rem 1.2rem 6rem;max-width:420px;margin:0 auto}}:root{--tarot-bg: #464445;--tarot-bg-light: #3e3c3d;--tarot-gold: #d4b87a;--tarot-gold-dim: rgba(212, 184, 122, .4);--tarot-gold-glow: rgba(212, 184, 122, .2);--tarot-text: #f5f0e8;--tarot-text-muted: #e0d8cc;--tarot-text-dim: #b8ad9e;--tarot-card-bg: rgba(0, 0, 0, .35);--tarot-card-border: rgba(212, 184, 122, .25)}.tarot-fullpage{height:100vh;overflow-y:scroll;scroll-snap-type:y mandatory;-webkit-overflow-scrolling:touch}.tarot-page{height:100vh;scroll-snap-align:start}.tarot-page--cover{position:relative;overflow:hidden;background:#1a1a1a}.tarot-cover-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.tarot-scroll-hint{position:absolute;bottom:max(2.5rem,env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:0;background:none;border:none;cursor:pointer;padding:.5rem 1.5rem;animation:tarot-hint-float 2s ease-in-out infinite}.tarot-scroll-hint-arrow{display:block;font-size:2rem;color:#d4b87ae6;transform:rotate(90deg);line-height:.6;text-shadow:0 0 12px rgba(212,184,122,.5)}.tarot-scroll-hint-text{margin-top:.5rem;font-size:.8rem;color:#f5f0e8cc;letter-spacing:.15em;text-shadow:0 1px 6px rgba(0,0,0,.6)}@keyframes tarot-hint-float{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-10px)}}.tarot-page--content{overflow-y:auto}.tarot-landing{min-height:100vh;background:#464445;color:var(--tarot-text);padding:0 0 6rem;overflow-x:hidden;position:relative}.tarot-section{max-width:540px;margin:0 auto;padding:1.5rem 1rem 1rem}.tarot-section-title{font-family:"Noto Serif SC",serif;font-size:var(--font-section-resp);font-weight:500;color:var(--tarot-gold);letter-spacing:.15em;text-align:center;margin-bottom:.4rem;text-shadow:0 2px 8px rgba(0,0,0,.5)}.tarot-section-subtitle{text-align:center;color:var(--tarot-text-muted);font-size:.8rem;letter-spacing:.08em;margin-bottom:1.5rem}.tarot-hero{text-align:center;padding:2rem 1rem 1.5rem;max-width:540px;margin:0 auto}.tarot-hero-title{font-family:"Noto Serif SC",serif;font-size:var(--font-title-resp);font-weight:500;color:var(--tarot-gold);letter-spacing:.25em;margin-bottom:.5rem;text-shadow:0 2px 10px rgba(0,0,0,.5)}.tarot-hero-desc{color:var(--tarot-text-muted);font-size:.85rem;letter-spacing:.1em;line-height:1.8}.crystal-scroll{display:flex;gap:1rem;overflow-x:auto;padding:.5rem 0 1rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.crystal-scroll::-webkit-scrollbar{display:none}.crystal-card{flex-shrink:0;width:90px;display:flex;flex-direction:column;align-items:center;gap:.5rem;scroll-snap-align:start}.crystal-icon{width:72px;height:72px;border-radius:10px;overflow:hidden;transition:transform .3s,box-shadow .3s}.crystal-img{width:100%;height:100%;object-fit:cover}.crystal-card:hover .crystal-icon{transform:scale(1.08);box-shadow:0 4px 16px #d4b87a59}.crystal-name{font-size:.75rem;color:var(--tarot-text-muted);text-align:center;letter-spacing:.05em}.crystal-brief{font-size:.65rem;color:var(--tarot-text-dim);text-align:center}.card-preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.card-preview-item{background:var(--tarot-card-bg);border:1px solid var(--tarot-card-border);border-radius:10px;padding:.4rem;text-align:center;cursor:pointer;transition:border-color .3s,box-shadow .3s,transform .3s;overflow:hidden}.card-preview-item:hover{border-color:var(--tarot-gold-dim);box-shadow:0 4px 20px var(--tarot-gold-glow);transform:translateY(-2px)}.card-preview-thumb{width:100%;height:auto;display:block;border-radius:6px}.member-teaser{position:relative;overflow:hidden;border-radius:12px;background:var(--tarot-card-bg);border:1px solid var(--tarot-card-border);padding:1.5rem 1rem}.member-teaser-blur{filter:blur(4px);-webkit-user-select:none;user-select:none;pointer-events:none}.member-teaser-blur p{color:var(--tarot-text-muted);font-size:.85rem;line-height:2;margin-bottom:.5rem}.member-teaser-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(to bottom,transparent 10%,rgba(70,68,69,.95) 60%);gap:.8rem;padding:1rem}.member-teaser-title{font-family:"Noto Serif SC",serif;font-size:1.1rem;color:var(--tarot-gold);letter-spacing:.12em}.member-teaser-list{list-style:none;padding:0;margin:0;text-align:center}.member-teaser-list li{color:var(--tarot-text-muted);font-size:.78rem;line-height:2;letter-spacing:.05em}.member-teaser-list li:before{content:"✦ ";color:var(--tarot-gold-dim)}.member-teaser-btn{margin-top:.5rem;background:transparent;border:1px solid var(--tarot-gold);color:var(--tarot-gold);border-radius:6px;padding:.55rem 1.8rem;font-size:.85rem;letter-spacing:.1em;cursor:pointer;transition:background .3s,color .3s}.member-teaser-btn:hover{background:var(--tarot-gold);color:var(--tarot-bg)}.floating-cta{position:fixed;bottom:0;left:0;right:0;padding:.8rem 1.2rem;padding-bottom:max(.8rem,env(safe-area-inset-bottom));background:linear-gradient(to top,rgba(0,0,0,.6) 40%,transparent);display:flex;justify-content:center;z-index:100}.floating-cta-btn{width:100%;max-width:380px;height:48px;background:linear-gradient(135deg,var(--tarot-gold),#d4b87a);color:var(--tarot-bg);border:none;border-radius:8px;font-size:.95rem;font-weight:500;letter-spacing:.12em;cursor:pointer;transition:opacity .2s,transform .2s}.floating-cta-btn:hover{opacity:.9;transform:translateY(-1px)}.tarot-auth-overlay{position:fixed;inset:0;background:#464445b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tarot-auth-modal{background:#3c3a3b;border:1px solid var(--tarot-card-border);border-radius:14px;padding:2rem 1.5rem;width:100%;max-width:360px;position:relative}.tarot-auth-close{position:absolute;top:.8rem;right:.8rem;background:none;border:none;font-size:1.4rem;color:var(--tarot-text-dim);cursor:pointer;line-height:1}.tarot-auth-title{font-family:"Noto Serif SC",serif;font-size:1.2rem;color:var(--tarot-gold);text-align:center;letter-spacing:.12em;margin-bottom:1.2rem}.tarot-auth-row{margin-bottom:1rem}.tarot-auth-label{display:block;font-size:.78rem;color:var(--tarot-text-muted);margin-bottom:.3rem}.tarot-auth-input-row{display:flex;gap:.5rem}.tarot-auth-input{flex:1;min-width:0;height:44px;padding:0 .8rem;background:#ffffff0f;border:1px solid var(--tarot-card-border);border-radius:6px;color:var(--tarot-text);font-size:.95rem;outline:none;transition:border-color .2s}.tarot-auth-input:focus{border-color:var(--tarot-gold-dim)}.tarot-auth-input::placeholder{color:var(--tarot-text-dim)}.tarot-auth-send-btn{flex-shrink:0;height:44px;padding:0 .7rem;white-space:nowrap;background:transparent;border:1px solid var(--tarot-gold);color:var(--tarot-gold);border-radius:6px;font-size:.8rem;cursor:pointer;transition:background .2s,color .2s}.tarot-auth-send-btn:hover:not(:disabled){background:var(--tarot-gold);color:var(--tarot-bg)}.tarot-auth-send-btn:disabled{opacity:.4;cursor:not-allowed}.tarot-auth-code-input{text-align:center;letter-spacing:.3em}.tarot-auth-agreement{display:flex;align-items:center;gap:.5rem;margin:1rem 0}.tarot-auth-agreement input[type=checkbox]{-webkit-appearance:checkbox;appearance:checkbox;accent-color:var(--tarot-gold);width:18px;height:18px;flex-shrink:0;cursor:pointer}.tarot-auth-agreement label{font-size:.75rem;color:var(--tarot-text-muted)}.tarot-auth-agreement a{color:var(--tarot-gold);text-decoration:none}.tarot-auth-submit{width:100%;height:44px;background:linear-gradient(135deg,var(--tarot-gold),#d4b87a);color:var(--tarot-bg);border:none;border-radius:6px;font-size:.9rem;font-weight:500;letter-spacing:.1em;cursor:pointer;transition:opacity .2s}.tarot-auth-submit:disabled{opacity:.4;cursor:not-allowed}.tarot-auth-error{color:#e74c3c;font-size:.78rem;text-align:center;margin-bottom:.8rem}.gallery-page{min-height:100vh;background:#464445;padding:1rem .8rem 2rem;position:relative}.gallery-header{max-width:540px;margin:0 auto 1.5rem;text-align:center}.gallery-back{display:inline-block;color:var(--tarot-text-muted);font-size:.85rem;text-decoration:none;margin-bottom:1rem;cursor:pointer;background:none;border:none}.gallery-back:hover{color:var(--tarot-gold)}.gallery-title{font-family:"Noto Serif SC",serif;font-size:var(--font-section-resp);color:var(--tarot-gold);letter-spacing:.2em;text-shadow:0 2px 8px rgba(0,0,0,.5)}.gallery-grid{max-width:540px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}.gallery-card{background:var(--tarot-card-bg);border:1px solid var(--tarot-card-border);border-radius:10px;padding:.8rem .5rem;text-align:center;cursor:pointer;transition:border-color .3s,box-shadow .3s,transform .3s}.gallery-card:hover{border-color:var(--tarot-gold-dim);box-shadow:0 4px 20px var(--tarot-gold-glow);transform:translateY(-3px)}.gallery-card-color{width:52px;height:52px;margin:0 auto .5rem;object-fit:cover;border-radius:8px}.gallery-card-name{font-family:"Noto Serif SC",serif;font-size:.85rem;color:var(--tarot-text);letter-spacing:.05em;margin-bottom:.2rem}.gallery-card-en{font-size:.6rem;color:var(--tarot-text-dim);font-style:italic}.card-detail{min-height:100vh;background:#464445;padding:1rem .8rem 2rem;position:relative}.card-detail-content{max-width:480px;margin:0 auto}.card-detail-back{display:inline-block;color:var(--tarot-text-muted);font-size:.85rem;cursor:pointer;background:none;border:none;margin-bottom:1.5rem}.card-detail-back:hover{color:var(--tarot-gold)}.card-detail-hero{text-align:center;margin-bottom:2rem}.card-detail-gem{width:clamp(100px,28vw,140px);height:clamp(100px,28vw,140px);margin:0 auto 1rem;object-fit:cover;border-radius:12px}.card-detail-name{font-family:"Noto Serif SC",serif;font-size:var(--font-title-resp);color:var(--tarot-gold);letter-spacing:.2em;margin-bottom:.3rem}.card-detail-en{font-size:.85rem;color:var(--tarot-text-dim);font-style:italic;letter-spacing:.1em}.card-detail-meaning{background:var(--tarot-card-bg);border:1px solid var(--tarot-card-border);border-radius:12px;padding:1rem .8rem;margin-bottom:1.5rem}.card-detail-meaning h3{font-family:"Noto Serif SC",serif;font-size:1rem;color:var(--tarot-gold);letter-spacing:.1em;margin-bottom:.8rem}.card-detail-meaning p{color:var(--tarot-text-muted);font-size:.88rem;line-height:1.9;letter-spacing:.03em}.card-detail-attrs{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.card-detail-attr{background:var(--tarot-card-bg);border:1px solid var(--tarot-card-border);border-radius:10px;padding:.8rem .5rem;text-align:center}.card-detail-attr-label{font-size:.65rem;color:var(--tarot-text-dim);margin-bottom:.3rem;letter-spacing:.05em}.card-detail-attr-value{font-size:.8rem;color:var(--tarot-text);letter-spacing:.05em}.card-modal-overlay{position:fixed;inset:0;background:#000000e6;z-index:2000}.card-modal-close{position:fixed;top:max(.8rem,env(safe-area-inset-top,0px));right:.8rem;z-index:2001;background:#00000080;border:1px solid rgba(255,255,255,.2);color:var(--tarot-text);font-size:1.6rem;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.card-modal-scroll{height:100%;overflow-y:scroll;scroll-snap-type:y mandatory;-webkit-overflow-scrolling:touch}.card-modal-page{height:100vh;scroll-snap-align:start;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;padding:1rem}.card-modal-img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:8px}.card-modal-hint-bar{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.7) 30%,transparent);padding:3rem 0 0;display:flex;justify-content:center;pointer-events:none}.card-modal-hint{position:relative;bottom:max(1.5rem,env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;align-items:center;gap:0;background:none;border:none;cursor:pointer;padding:.5rem 2rem;pointer-events:auto;animation:card-modal-hint-bounce 1.8s ease-in-out infinite}.card-modal-hint-arrow{display:block;font-size:2.2rem;color:var(--tarot-gold);transform:rotate(90deg);line-height:.55;text-shadow:0 0 16px rgba(212,184,122,.6)}.card-modal-hint-text{margin-top:.5rem;font-size:.85rem;color:#f5f0e8e6;letter-spacing:.12em;text-shadow:0 1px 8px rgba(0,0,0,.8)}@keyframes card-modal-hint-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.image-loader-wrapper{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.image-loader-hint{position:absolute;display:flex;flex-direction:column;align-items:center;gap:.75rem}.image-loader-spinner{width:36px;height:36px;border:3px solid rgba(212,184,122,.2);border-top-color:var(--tarot-gold);border-radius:50%;animation:image-loader-spin .8s linear infinite}.image-loader-text{font-size:.85rem;color:var(--tarot-text-muted)}.image-loader-img{opacity:0;transition:opacity .3s ease}.image-loader-img.image-loader-visible{opacity:1}@keyframes image-loader-spin{to{transform:rotate(360deg)}}.card-detail-desc-img{width:100%;border-radius:8px}@media(min-width:480px){.tarot-section{padding:2.5rem 1.2rem 1rem}.tarot-hero{padding:3rem 1.2rem 2rem}.card-preview-grid{gap:.8rem}.card-preview-item{padding:1rem .8rem}.member-teaser{padding:2rem 1.2rem}.gallery-page{padding:1.5rem 1.2rem 2rem}.gallery-grid{grid-template-columns:repeat(3,1fr)}.gallery-card{padding:1rem .6rem}.card-detail{padding:1.5rem 1.2rem 3rem}.card-detail-attrs{grid-template-columns:1fr 1fr 1fr}.card-detail-gem{width:140px;height:140px}.card-detail-meaning{padding:1.5rem 1.2rem}}@media(min-width:768px){.tarot-hero-title{letter-spacing:.25em}}
