:root{--bg-from:#ffdcc1;--bg-to:#ff9a5a;--accent:#d96a2b;--heading:#5b2e1a;--accent-contrast:#fff;--muted:#8a6b5a;--text:#362e2a;--card-bg:#fff;--radius:12px;--card-padding:16px;--shadow:0 18px 56px #582e121f}*{box-sizing:border-box}html,body,#root{height:100%}body{color:var(--text);background-image:radial-gradient(circle at 8% 8%, #d96a2b1f, transparent 34%), linear-gradient(180deg, var(--bg-from) 0%, var(--bg-to) 100%);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial}.app{flex-direction:column;justify-content:flex-start;align-items:center;min-height:100vh;padding:32px 24px;display:flex}.container{flex-direction:column;width:100%;max-width:1000px;min-height:100vh;display:flex}.topbar-inner{justify-content:space-between;align-items:center;width:100%;max-width:1000px;margin:0 auto;padding:0 14px;display:flex}.topbar{align-items:center;gap:1rem;margin-bottom:20px;display:flex}.brand{flex-direction:column;display:flex}.brand h1{color:var(--heading);margin:0;font-size:1.8rem}.brand .subtitle{color:var(--muted);margin-top:4px;font-size:.95rem}.brand-title{margin:0;font-size:2rem;line-height:1}.brand-sub{color:var(--muted);margin-top:6px;font-size:.95rem}.profile-area{align-items:center;gap:.75rem;margin-left:auto;display:flex}.profile-action{margin-left:.4rem}.profile{align-items:center;gap:10px;display:flex}.profile-noavatar{align-items:center;display:flex}.profile-avatar{color:#7a3f23;background:#fff0e6;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:700;display:flex}.profile-meta{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.profile-name{color:var(--heading);font-size:.95rem;font-weight:700}.profile-action .btn{border-radius:8px;padding:6px 10px;font-size:.9rem}.card{background:var(--card-bg);border-radius:var(--radius);padding:var(--card-padding);box-shadow:var(--shadow);margin-bottom:14px}.btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:.5rem;padding:10px 14px;font-weight:600;transition:transform .12s,box-shadow .12s,opacity .12s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent);color:var(--accent-contrast);box-shadow:0 14px 36px #d96a2b2e}.btn-secondary{color:var(--text);background:#fff6f1;border:1px solid #582e120a}.btn-refresh{color:var(--text);background:0 0;border:1px solid #582e120f;padding:8px 10px}.btn:hover:not(:disabled){transform:translateY(-2px)}.btn-login{color:#fff;background:#b06a2d;box-shadow:0 12px 28px #b06a2d24}.btn-login:hover:not(:disabled){transform:translateY(-2px)scale(1.01);box-shadow:0 18px 40px #b06a2d33}.btn-logout{color:#fff;background:#a83e3e;box-shadow:0 12px 28px #a83e3e1f}.btn-logout:hover:not(:disabled){transform:translateY(-2px)scale(1.01);box-shadow:0 18px 40px #a83e3e2e}.small{color:var(--muted);font-size:.85rem}.footer{text-align:center;color:var(--muted);margin-top:18px}@media (width<=820px){.topbar{flex-direction:column;align-items:flex-start;gap:8px}.brand h1{font-size:1.6rem}.brand{width:100%}.profile-meta{align-items:flex-start}}main{flex:1;margin-bottom:18px}.heading-quiet{color:var(--muted);margin-bottom:8px;font-size:1rem}.error-banner{color:#a94442;background:#fdd;border:1px solid #ebccd1;border-radius:4px;justify-content:space-between;align-items:center;margin:16px 0;padding:12px 16px;font-size:1rem;display:flex;box-shadow:0 2px 8px #0000000d}.error-banner-close{color:#a94442;cursor:pointer;background:0 0;border:none;margin-left:16px;font-size:1.5rem}:root{--gap:12px}.greetings-manager{width:100%;max-width:1000px;color:var(--text);margin:0 auto;padding:8px 0}.gm-container{gap:var(--gap);display:block}.gm-container.single{justify-content:center;align-items:center;min-height:220px;padding:20px 12px;display:flex}.center-card{text-align:center;width:100%;max-width:640px;padding:20px}.gm-container.single .alert{margin-bottom:12px}.page-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.page-title{color:var(--heading);margin:0;font-size:1.1rem;font-weight:700}.card{border-radius:var(--radius);background:var(--card-bg);padding:14px;box-shadow:0 6px 18px #582e120f}.form-card h2{color:var(--heading);margin:0 0 10px;font-size:1.02rem}.form-group{margin-bottom:10px}.form-group label{margin-bottom:6px;font-size:.9rem;font-weight:600;display:block}.form-group input,.form-group textarea{border:1px solid #582e120f;border-radius:10px;width:100%;padding:10px 12px;font-size:.95rem}.form-group input:focus,.form-group textarea:focus{outline:none;box-shadow:0 6px 18px #d96a2b0f}.form-actions{flex-direction:column;gap:10px;display:flex}.form-actions .btn{width:100%}.not-auth{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.not-auth p{color:var(--muted);margin:0}.list-card{padding:8px}.list-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.list-header h2{margin:0;font-size:1rem}.greeting-cards{grid-template-columns:1fr;gap:12px;display:grid}.greeting-card{background:var(--card-bg);border-radius:10px;padding:12px;box-shadow:0 6px 18px #582e120a}.greeting-header{align-items:center;gap:12px;display:flex}.greeting-avatar{color:#7a3f23;background:#fff0e6;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-weight:700;display:flex}.greeting-meta h3{color:var(--heading);margin:0;font-size:1rem}.greeting-date{color:var(--muted);font-size:.82rem}.greeting-message{white-space:pre-wrap;overflow-wrap:anywhere;margin:8px 0 0;line-height:1.5}.greeting-actions{justify-content:flex-end;gap:8px;display:flex}.btn-icon{cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px}.btn-icon:hover{background:#582e120a}.empty-state,.loading-state{text-align:center;color:var(--muted);padding:16px}.alert{color:#7a3f23;background:#fff6f1;border-radius:8px;margin-bottom:10px;padding:10px}.alert.alert-info{color:#7a1a1a;background:linear-gradient(90deg,#ffebeb,snow);border:1px solid #7a1a1a14;margin-bottom:12px;padding:14px;box-shadow:0 8px 24px #7a1a1a14}.alert.alert-info p{color:#7a1a1a;margin:0;font-weight:700}@media (width>=820px){.gm-container{grid-template-columns:320px minmax(420px,1fr);justify-content:start;align-items:start;gap:18px;display:grid}.form-actions{flex-direction:row}.form-actions .btn{flex:1}.greeting-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}.right .list-card{max-width:760px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
