:root{--purple: #7c3aed;--pink: #ec4899;--ink: #1f2937;--muted: #6b7280;--line: #e5e7eb;--bg: #fbfaff;--blue: #2563eb;--d-bg: #f5f6f8;--d-line: #e5e7eb;--d-ink: #1f2937;--d-mid: #4b5563;--d-mute: #6b7280;--d-mute2: #9ca3af;--d-danger: #dc2626}*{box-sizing:border-box}body{margin:0;font-family:Helvetica Neue,Arial,PingFang TC,Microsoft JhengHei,sans-serif;color:var(--ink);background:var(--bg)}a{color:var(--purple)}button{font-family:inherit;cursor:pointer}.loading-screen,.loading{padding:60px;text-align:center;color:var(--muted)}.error-box{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;padding:10px 14px;border-radius:10px;margin:10px 0}.err{color:#b91c1c}.err.small{font-size:12px}.muted{color:var(--muted)}.btn{background:var(--purple);color:#fff;border:none;padding:12px 26px;border-radius:999px;font-size:15px;font-weight:600}.btn:hover{filter:brightness(1.05)}.btn:disabled{opacity:.6;cursor:default}.btn.ghost{background:#fff;color:var(--purple);border:1px solid var(--purple)}.link-btn{background:none;border:none;color:var(--purple);text-decoration:underline;padding:0}.link-btn.danger{color:#b91c1c}.page{max-width:1080px;margin:0 auto;padding:0 20px 60px}.page.narrow{max-width:620px}.topbar{display:flex;justify-content:space-between;align-items:center;padding:18px 0}.brand{font-size:22px;font-weight:800}.brand span{color:var(--purple)}.topbar-right{display:flex;align-items:center;gap:12px}.badge{background:#ede9fe;color:var(--purple);font-size:12px;padding:3px 10px;border-radius:999px;font-weight:700}.who{color:var(--muted);font-size:14px}.hero{text-align:center;padding:40px 0 30px}.hero h1{font-size:34px;margin:0 0 12px;background:linear-gradient(135deg,var(--purple),var(--pink));-webkit-background-clip:text;background-clip:text;color:transparent}.hero p{color:var(--muted);font-size:17px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:22px}.card-tile{text-decoration:none;color:inherit;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;transition:transform .15s,box-shadow .15s}.card-tile:hover{transform:translateY(-4px);box-shadow:0 12px 30px #7c3aed24}.tile-art{height:150px;display:flex;align-items:center;justify-content:center}.tile-emoji{font-size:60px}.tile-info{padding:14px 16px 18px}.tile-cat{font-size:12px;color:var(--purple);font-weight:700}.tile-info h3{margin:4px 0 6px}.tile-info p{margin:0;color:var(--muted);font-size:14px}.empty{color:var(--muted);padding:40px}.foot{text-align:center;color:var(--muted);font-size:13px;padding-top:50px}.page.split{max-width:1040px;margin:0 auto;padding:30px 20px 60px;display:grid;grid-template-columns:1fr 1fr;gap:36px}.back{display:inline-block;margin-bottom:14px;text-decoration:none}.form-col label{display:block;margin-bottom:14px;font-size:14px;font-weight:600}.form-col input,.form-col textarea,.inline-form input,.inline-form select,.card-form input,.card-form textarea,.card-form select{width:100%;margin-top:6px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;font-size:15px;font-weight:400;font-family:inherit}.form-col input[type=color]{padding:4px;height:42px}.success-box{background:#fff;border:1px solid var(--line);border-radius:16px;padding:36px;text-align:center}.success-box h2{margin-top:0}.share-link{display:block;word-break:break-all;background:#faf5ff;padding:10px;border-radius:8px;margin:8px 0 20px;font-size:13px}.actions{display:flex;gap:12px;justify-content:center}.card-canvas{position:relative;border-radius:18px;min-height:360px;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 40px #00000014}.card-inner{position:relative;z-index:2;text-align:center;padding:30px}.card-emoji{font-size:76px;margin-bottom:6px;animation:bob 2.4s ease-in-out infinite}.card-inner h2{margin:6px 0;font-size:26px}.card-to{font-weight:600}.card-msg{white-space:pre-wrap;color:#444;max-width:360px;margin:14px auto;line-height:1.7}.card-from{color:var(--muted)}.card-floats{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.float{position:absolute;bottom:-30px;opacity:.6;animation:rise 6s linear infinite}@keyframes rise{0%{transform:translateY(0);opacity:0}10%{opacity:.7}to{transform:translateY(-420px);opacity:0}}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.card-view-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,#f5f3ff,#fdf2f8)}.card-view-inner{width:100%;max-width:520px}.view-footer{text-align:center;color:var(--muted);font-size:13px;margin-top:16px}.envelope{text-align:center;cursor:pointer}.envelope-flap{font-size:90px;animation:bob 2.4s ease-in-out infinite}.envelope p{font-size:18px;color:var(--muted);margin:8px 0 18px}.gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#f5f3ff,#fdf2f8);padding:24px}.gate-box{background:#fff;border-radius:18px;padding:44px 40px;text-align:center;max-width:420px;box-shadow:0 16px 50px #7c3aed26}.gate-logo{font-weight:800;color:var(--purple);letter-spacing:1px}.gate-box h1{margin:12px 0}.gate-box p{color:var(--muted)}.google-login{display:flex;flex-direction:column;align-items:center;margin-top:18px}.admin{display:grid;grid-template-columns:240px 1fr;min-height:100vh;background:var(--d-bg);color:var(--d-ink)}.admin-nav{background:#fff;border-right:1px solid var(--d-line);display:flex;flex-direction:column}.admin-brand{height:56px;display:flex;flex-direction:column;justify-content:center;padding:0 20px;border-bottom:1px solid var(--d-line)}.admin-brand .b1{font-size:14px;font-weight:800;letter-spacing:1px;color:var(--d-ink)}.admin-brand .b2{font-size:10px;letter-spacing:3px;color:var(--d-mute2)}.admin-nav nav{flex:1;overflow-y:auto;padding:14px 0;display:flex;flex-direction:column}.admin-nav a{display:flex;align-items:center;gap:12px;padding:10px 20px;font-size:14px;color:var(--d-mid);text-decoration:none;transition:background .15s,color .15s}.admin-nav a:hover{background:var(--d-bg)}.admin-nav a.active{background:#2563eb1a;color:var(--blue);font-weight:600;box-shadow:inset -2px 0 0 var(--blue)}.admin-user{border-top:1px solid var(--d-line);padding:12px}.admin-user-row{display:flex;align-items:center;gap:8px;padding:2px 6px 8px}.admin-user-row img{width:32px;height:32px;border-radius:50%;object-fit:cover;background:var(--d-bg)}.admin-user-meta{min-width:0}.admin-user-meta .nm{font-size:12px;font-weight:600;color:var(--d-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-user-meta .em{font-size:10px;color:var(--d-mute2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-logout{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:var(--d-mute);background:none;border:none;padding:8px;border-radius:8px}.admin-logout:hover{background:var(--d-bg)}.admin-main{padding:24px 32px;overflow:auto}.admin-main h1{margin-top:0;font-size:20px}.admin-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--d-bg);padding:16px}.admin-gate-wrap{width:100%;max-width:360px}.admin-gate-brand{text-align:center;margin-bottom:28px}.admin-gate-brand .b1{font-size:24px;font-weight:800;letter-spacing:1px;color:var(--d-ink)}.admin-gate-brand .b2{font-size:13px;letter-spacing:3px;color:var(--d-mute);margin-top:4px}.admin-gate-card{background:#fff;border:1px solid var(--d-line);border-radius:14px;box-shadow:0 2px 8px #0000000a;padding:32px;text-align:center}.admin-gate-card h2{font-size:16px;margin:0 0 4px;color:var(--d-ink)}.admin-gate-card p{font-size:12px;color:var(--d-mute);margin:0 0 22px}.admin-gate-btn{display:flex;justify-content:center}.admin-gate-foot{text-align:center;color:var(--d-mute2);font-size:11px;margin-top:22px}.admin .btn{background:var(--blue);border-radius:8px;padding:9px 18px;font-size:14px}.admin .btn.ghost{background:#fff;color:var(--blue);border-color:var(--blue)}.admin .link-btn{color:var(--blue)}.admin .link-btn.danger{color:var(--d-danger)}.inline-form{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:18px 0}.inline-form input,.inline-form select{width:auto;margin:0}.chk,.chk2{display:inline-flex;align-items:center;gap:6px;font-size:14px}.tbl{width:100%;border-collapse:collapse;margin-top:10px;background:#fff;border:1px solid var(--d-line);border-radius:12px;overflow:hidden}.tbl th,.tbl td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--d-line);font-size:14px}.tbl tr:last-child td{border-bottom:none}.tbl th{background:#f9fafb;color:var(--d-mute);font-weight:600}.tbl select{width:auto;margin:0;padding:5px 8px}.self-tag{background:#2563eb1a;color:var(--blue);font-size:11px;padding:1px 7px;border-radius:999px;margin-left:6px}.card-form{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;margin:16px 0 24px}.card-form .grid2{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.card-form label{font-size:13px;font-weight:600}.card-form .chk2{align-self:end;padding-bottom:10px}.mini-art{display:inline-flex;width:34px;height:34px;border-radius:8px;align-items:center;justify-content:center}.pill{border:1px solid var(--line);background:#fff;border-radius:999px;padding:4px 12px;font-size:13px}.pill.on{background:#dcfce7;border-color:#86efac;color:#15803d}.stat{padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}.stat.gray{background:#f3f4f6;color:#6b7280}.stat.blue{background:#dbeafe;color:#1d4ed8}.stat.green{background:#dcfce7;color:#15803d}.stat.red{background:#fee2e2;color:#b91c1c}.setting-card{display:flex;justify-content:space-between;align-items:center;gap:24px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 24px;margin:18px 0}.setting-card h3{margin:0 0 6px}.switch{position:relative;display:inline-block;width:54px;height:30px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#ccc;border-radius:999px;transition:.2s}.slider:before{content:"";position:absolute;height:22px;width:22px;left:4px;bottom:4px;background:#fff;border-radius:50%;transition:.2s}.switch input:checked+.slider{background:var(--blue)}.switch input:checked+.slider:before{transform:translate(24px)}@media (max-width: 760px){.page.split{grid-template-columns:1fr}.card-form .grid2{grid-template-columns:repeat(2,1fr)}.admin{grid-template-columns:1fr}.admin-nav{flex-direction:row;align-items:center;overflow-x:auto;border-right:none;border-bottom:1px solid var(--d-line)}.admin-brand{height:auto;padding:12px 16px;border-bottom:none;border-right:1px solid var(--d-line);flex-shrink:0}.admin-nav nav{flex-direction:row;padding:0;flex:0 0 auto}.admin-nav a{white-space:nowrap}.admin-nav a.active{box-shadow:inset 0 -2px 0 var(--blue)}.admin-user{display:none}.admin-main{padding:18px 16px}}
