:root{--bg: #fbf7f0;--card: #ffffff;--ink: #1f2937;--muted: #6b7280;--accent: #b45309;--accent-ink: #fff;--line: #ece4d8;--radius: 16px;--shadow: 0 6px 24px rgba(31, 41, 55, .08)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:var(--bg);color:var(--ink);font-family:ui-rounded,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased}.app{max-width:640px;margin:0 auto;padding:env(safe-area-inset-top) 16px calc(env(safe-area-inset-bottom) + 88px)}h1,h2,h3{font-weight:700;letter-spacing:-.01em}.script{font-family:Snell Roundhand,Brush Script MT,cursive;color:var(--accent)}.center{min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin:14px 0}.muted{color:var(--muted)}.small{font-size:13px}label{display:block;font-size:14px;font-weight:600;margin:14px 0 6px}input[type=text],input[type=email]{width:100%;padding:13px 14px;border:1px solid #e2d9cb;border-radius:12px;font-size:16px;background:#fff}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:12px;padding:14px 18px;font-size:16px;font-weight:600;cursor:pointer;text-decoration:none;width:100%}.btn-primary{background:var(--accent);color:var(--accent-ink)}.btn-primary:disabled{opacity:.5}.btn-ghost{background:#f3ece1;color:var(--ink)}.btn-row{display:flex;gap:10px}.header{text-align:center;padding:22px 0 6px}.header .names{font-size:30px}.header .date{color:var(--muted);font-size:14px}.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.grid.admin{grid-template-columns:repeat(3,1fr)}.tile{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;background:#efe7da}.tile img{width:100%;height:100%;object-fit:cover;display:block}.tile.uploading{display:flex;align-items:center;justify-content:center}.badge{position:absolute;top:6px;left:6px;font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px;background:#0009;color:#fff;text-transform:uppercase}.badge.pending{background:#d97706}.badge.rejected{background:#b91c1c}.badge.photographer{background:#1d4ed8}.tile .actions{position:absolute;bottom:0;left:0;right:0;display:flex;gap:4px;padding:5px;background:linear-gradient(transparent,#0009)}.tile .actions button{flex:1;border:none;border-radius:8px;padding:6px 0;font-size:12px;font-weight:700;cursor:pointer}.fab{position:fixed;left:50%;transform:translate(-50%);bottom:calc(env(safe-area-inset-bottom) + 18px);width:min(608px,calc(100% - 32px));z-index:20}.tabbar{display:flex;gap:8px;margin:8px 0 4px}.tabbar a{flex:1;text-align:center;padding:10px;border-radius:12px;text-decoration:none;color:var(--muted);font-weight:600;background:#f3ece1}.tabbar a.active{background:var(--accent);color:#fff}.qr{display:block;margin:10px auto;width:220px;height:220px;border-radius:12px}.toggle{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f0e8db}.toggle:last-child{border-bottom:none}.spinner{width:26px;height:26px;border:3px solid rgba(0,0,0,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error{color:#b91c1c;font-size:14px}.notice{background:#fef3c7;border-radius:12px;padding:12px 14px;font-size:14px}.toast{position:fixed;bottom:90px;left:50%;transform:translate(-50%);background:#1f2937;color:#fff;padding:10px 16px;border-radius:999px;font-size:14px;z-index:50}.install-banner{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:#1f2937;color:#fff;font-size:14px}.install-banner button{border:none;border-radius:8px;padding:7px 12px;font-weight:600;cursor:pointer;background:var(--accent);color:#fff}.install-banner button.ghost{background:transparent;color:#cbd5e1}
