@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;700&display=swap";:root{--primary-color:#f472b6;--bg-color:#fdfaf6;--panel-bg:#ffffffa6;--glass-border:#fffc;--text-main:#334155;--text-muted:#64748b;--accent:#e879f9;--radius:20px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);min-height:100vh;font-family:Outfit,sans-serif;overflow-x:hidden}#ambient-glow{pointer-events:none;z-index:2;background:radial-gradient(circle at var(--mouse-x,50vw) var(--mouse-y,50vh), #fda4af66 0%, #d8b4fe33 20%, transparent 50%);transition:background .1s linear;position:fixed;inset:0}.background-gallery{z-index:1;column-count:12;opacity:.85;column-gap:20px;width:104vw;height:110vh;padding:20px;position:fixed;top:-5vh;left:-2vw;overflow:hidden}@media (width<=1200px){.background-gallery{column-count:8}}@media (width<=768px){.background-gallery{column-count:4}}@media (width<=480px){.background-gallery{column-count:3}}.bg-thumb{cursor:pointer;break-inside:avoid;box-shadow:0 0 45px 15px var(--hex);border-radius:8px;margin-bottom:25px;transition:transform .4s,box-shadow .4s,filter .4s;position:relative}.bg-thumb img{border-radius:8px;width:100%;height:auto;transition:transform .4s;display:block}.bg-thumb-overlay{pointer-events:none;background:radial-gradient(circle at center, transparent 30%, var(--hex) 120%);box-shadow:inset 0 0 20px 2px var(--hex);mix-blend-mode:overlay;opacity:.7;border-radius:8px;transition:opacity .3s;position:absolute;inset:0}.bg-thumb:hover{box-shadow:0 0 80px 30px var(--hex);z-index:10;filter:brightness(1.1);transform:translateY(-5px)scale(1.05)}.bg-thumb:hover .bg-thumb-overlay{opacity:.3}.bg-thumb.empty{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#fff6;height:200px}.app-container{background:var(--panel-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius);z-index:50;max-width:900px;margin:4vh auto;padding:2.5rem;position:relative;box-shadow:0 15px 35px #0000000d}.app-header{text-align:center;margin-bottom:2rem;animation:.8s fadeInDown}.app-header h1{background:linear-gradient(135deg, var(--accent), #60a5fa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:3.5rem;font-weight:700}.app-header p{color:var(--text-muted);font-size:1.2rem}.upload-section{border-radius:calc(var(--radius) - 4px);border:1px solid var(--glass-border);background:#fff6;margin-bottom:3rem;padding:2rem;animation:.8s .2s both fadeInUp;box-shadow:0 4px 15px #00000005}.form-group.row{align-items:stretch;gap:2rem;display:flex}.file-drop-area{border-radius:var(--radius);cursor:pointer;background:#ffffff80;border:2px dashed #33415533;flex:1;justify-content:center;align-items:center;min-height:220px;transition:all .3s;display:flex;position:relative;overflow:hidden}.file-drop-area:hover{border-color:var(--accent);background:#e879f91a}.upload-placeholder{color:var(--text-muted);flex-direction:column;align-items:center;gap:1rem;display:flex}.image-preview{object-fit:cover;width:100%;height:100%;position:absolute;top:0;left:0}.form-controls{flex-direction:column;flex:1;justify-content:center;gap:1.5rem;display:flex}.input-with-icon{position:relative}.input-with-icon svg{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.input-with-icon input{border:1px solid var(--glass-border);width:100%;color:var(--text-main);background:#ffffffb3;border-radius:8px;padding:1.2rem 1.2rem 1.2rem 3.5rem;font-family:inherit;font-size:1.1rem;transition:all .3s}.input-with-icon input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #e879f933}.submit-btn{background:linear-gradient(135deg, var(--accent), #9333ea);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.8rem;padding:1.2rem;font-size:1.2rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 15px #e879f94d}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #e879f980}.submit-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;background:#0000001a}@media (width<=768px){.form-group.row{flex-direction:column}.app-container{margin:2vh auto;padding:1.5rem}}.palette-section h2{color:var(--text-main);margin-bottom:1.5rem;font-size:1.8rem}.palette-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;display:grid}.palette-card{border-radius:calc(var(--radius) - 4px);border:1px solid var(--glass-border);cursor:pointer;background:#fffc;transition:all .4s cubic-bezier(.175,.885,.32,1.275);animation:.6s both zoomIn;overflow:hidden;box-shadow:0 10px 20px #0000000d}.palette-card:hover{border-color:#fff;transform:translateY(-8px)scale(1.03);box-shadow:0 15px 30px #0000001a}.photo-container{height:160px;overflow:hidden}.photo-container img{object-fit:cover;width:100%;height:100%;transition:transform .6s}.palette-card:hover .photo-container img{transform:scale(1.1)}.color-info{justify-content:center;align-items:center;height:70px;transition:all .3s;display:flex;position:relative}.color-details{letter-spacing:1px;text-shadow:0 1px 2px #0003;flex-direction:column;align-items:center;gap:.1rem;font-weight:600;display:flex}.color-details .hex{font-size:1.1rem}.color-details .date{opacity:.9;font-size:.8rem;font-weight:400}.empty-state{text-align:center;border-radius:var(--radius);color:var(--text-muted);border:1px dashed var(--glass-border);background:#fff6;padding:3rem}.fab-dashboard{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:var(--text-main);cursor:pointer;white-space:nowrap;background:#ffffffd9;border:1px solid #fff;border-radius:50px;align-items:center;gap:12px;padding:.8rem 2rem;font-size:1.1rem;font-weight:700;transition:all .3s;display:flex;position:fixed;bottom:2rem;left:50%;transform:translate(-50%);box-shadow:0 8px 30px #0000001a}.fab-dashboard:hover{background:#fff;transform:translate(-50%)translateY(-5px);box-shadow:0 12px 40px #00000026}.modal-header{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.close-dashboard-btn{color:var(--text-muted);cursor:pointer;opacity:.7;background:0 0;border:none;transition:opacity .2s,transform .2s}.close-dashboard-btn:hover{opacity:1;color:var(--text-main);transform:scale(1.1)}.slide-in{animation:.4s cubic-bezier(.16,1,.3,1) slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.admin-toggle-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:.5rem 1rem;font-weight:700;transition:all .2s;display:flex}.admin-toggle-btn:hover{background:#2563eb}.admin-desc{color:var(--text-muted);margin-bottom:2rem}.admin-table{border-collapse:collapse;text-align:left;width:100%}.admin-table th,.admin-table td{border-bottom:1px solid var(--glass-border);vertical-align:middle;padding:1rem}.admin-table th{color:var(--text-main);font-weight:600}.admin-table tr:hover{background:#fff6}.admin-action-btn{cursor:pointer;color:#fff;background:0 0;border:none;border-radius:4px;margin-right:5px;padding:6px;transition:all .2s}.admin-action-btn.edit{color:#2563eb;background:#3b82f61a}.admin-action-btn.edit:hover{background:#3b82f633}.admin-action-btn.delete{color:#dc2626;background:#ef44441a}.admin-action-btn.delete:hover{background:#ef444433}.table-responsive{overflow-x:auto}.user-greeting{background:#fff9;border-radius:8px;align-items:center;gap:1rem;padding:.5rem 1rem;display:flex;box-shadow:0 2px 10px #00000005}.logout-btn-clean{cursor:pointer;border:1px solid var(--glass-border);color:var(--text-main);background:0 0;border-radius:4px;padding:.4rem .8rem;font-weight:600;transition:all .3s}.logout-btn-clean:hover{background:#fff}.image-modal-overlay{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);z-index:1000;background:#ffffff4d;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.close-modal-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff4d;border:none;border-radius:50%;padding:5px;transition:all .3s;box-shadow:0 2px 10px #0000001a}.close-modal-btn:hover{color:#000;background:#fff9;transform:scale(1.1)}.modal-content{background:0 0;justify-content:center;align-items:center;max-width:100vw;max-height:100vh;animation:.3s zoomIn;display:flex;position:relative}.modal-image{object-fit:contain;filter:drop-shadow(0 10px 30px #0000001a);max-width:100vw;max-height:100vh;display:block}.modal-overlay-ui{pointer-events:none;background:linear-gradient(#0000 0%,#0003 100%);flex-direction:column;align-items:flex-start;gap:10px;padding:40px 20px 20px;display:flex;position:absolute;bottom:0;left:0;right:0}.modal-info-text{pointer-events:auto;color:#fff}.modal-info-text h3{text-shadow:0 2px 4px #0009;margin:0 0 5px;font-size:2rem;font-weight:700}.modal-info-text p{opacity:.9;text-shadow:0 2px 4px #0009;margin:0;font-size:1.1rem;font-weight:500}.modal-top-actions{z-index:1010;align-items:center;gap:15px;display:flex;position:absolute;top:1.5rem;right:2rem}.icon-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff4d;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.6rem;transition:all .2s;display:flex;box-shadow:0 2px 10px #0000001a}.icon-btn:hover{color:#000;background:#ffffffb3;transform:translateY(-3px)}.icon-btn.share:hover{color:#fff;background:#3b82f6e6}.icon-btn.report:hover{color:#fff;background:#ef4444e6}.modal-actions{pointer-events:auto;flex-flow:wrap;align-items:center;gap:20px;width:100%;padding-top:10px;display:flex}.emotion-btn{color:#fff;cursor:pointer;background:0 0;border:none;outline:none;flex-direction:column;align-items:center;gap:6px;padding:5px;transition:all .2s;display:flex}.emotion-btn:active{transform:scale(.9)}.emotion-btn:hover{filter:drop-shadow(0 4px 10px #ffffff4d);transform:translateY(-3px)scale(1.1)}.emotion-btn .icon{filter:drop-shadow(0 2px 4px #0009);font-size:2.2rem;line-height:1}.emotion-btn .count{text-shadow:0 2px 4px #000c;font-size:1.1rem;font-weight:800}.tab-btn{border:1px solid var(--glass-border);cursor:pointer;color:var(--text-main);background:#ffffff80;border-radius:50px;padding:.5rem 1.5rem;font-weight:700;transition:all .2s}.tab-btn:hover{background:#fffc}.tab-btn.active{background:var(--text-main);color:#fff;border-color:var(--text-main)}.ai-badge{color:#fff;vertical-align:text-bottom;text-shadow:none;background:linear-gradient(135deg,#8b5cf6,#ec4899);border-radius:50px;margin-left:10px;padding:3px 10px;font-size:.8rem;font-weight:700;display:inline-block;box-shadow:0 2px 8px #ec489966}.dashboard-footer{border-top:1px solid var(--glass-border);color:var(--text-main);opacity:.7;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;margin-top:50px;padding-top:20px;font-size:.85rem;display:flex}.dashboard-footer a{color:inherit;font-weight:500;text-decoration:none;transition:opacity .2s}.dashboard-footer a:hover{opacity:1;text-decoration:underline}.dashboard-footer .separator{opacity:.4}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes zoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.kakao-login-btn{color:#000;cursor:pointer;background-color:#fee500;border:none;border-radius:10px;margin:0;padding:1.2rem 2.2rem;font-size:1.1rem;font-weight:700;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 15px #fee50033}.kakao-login-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #fee50066}.google-login-btn{color:#555;cursor:pointer;background-color:#fff;border:1px solid #ddd;border-radius:10px;margin:0;padding:1.2rem 2.2rem;font-size:1.1rem;font-weight:700;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 15px #0000000d}.google-login-btn:hover{background-color:#f8f8f8;transform:translateY(-3px);box-shadow:0 6px 20px #0000001a}
