*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body{-webkit-font-smoothing:antialiased;width:100%;height:100%;font-family:system-ui,sans-serif}#root{width:100%;min-height:100%}.corkboard-bg{background-image:url(/cork.jpg);background-repeat:repeat;background-size:1400px}canvas{touch-action:none}.gallery-root{min-height:100vh;overflow-y:auto}.gallery-header{-webkit-backdrop-filter:blur(12px);background:#160c04cc;border-bottom:1px solid #ffd2782e;padding:36px 24px 26px}.gallery-header-inner{max-width:920px;margin:0 auto}.gallery-title{color:#f5e6c8;letter-spacing:3px;text-shadow:0 2px 10px #0009;font-family:Georgia,Times New Roman,serif;font-size:34px;font-weight:700}.gallery-subtitle{color:#f5e6c88c;letter-spacing:.5px;margin-top:5px;font-family:Georgia,serif;font-size:13px;font-style:italic}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:28px;max-width:920px;margin:0 auto;padding:36px 24px 60px;display:grid}.new-project-btn{cursor:pointer;color:#fff5dca6;background:#fff8e114;border:2px dashed #ffdc9673;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:10px;height:210px;transition:all .2s;display:flex}.new-project-btn:hover,.new-project-btn:focus{color:#fff8e8;background:#fff8e12e;border-color:#ffdc96bf;transform:translateY(-2px)}.new-project-plus{font-size:44px;font-weight:200;line-height:1}.new-project-label{letter-spacing:.8px;font-family:Georgia,serif;font-size:13px}.project-card{cursor:pointer;background:#fafaf0;border-radius:3px;flex-direction:column;height:210px;transition:transform .18s,box-shadow .18s;display:flex;position:relative;overflow:hidden;box-shadow:3px 6px 18px #00000061,1px 1px 4px #0000002e}.project-card:hover{transform:translateY(-4px)rotate(.4deg);box-shadow:5px 12px 28px #00000073}.project-card-preview{background-image:url(/cork.jpg);background-repeat:repeat;background-size:200px;flex:1;justify-content:center;align-items:flex-start;padding-top:14px;display:flex;position:relative}.project-card-pin{background:radial-gradient(circle at 35% 30%,#f54,#8b0000);border-radius:50%;flex-shrink:0;width:15px;height:15px;box-shadow:0 2px 5px #0000008c}.project-card-info{background:#fafaf0;border-top:1px solid #e5d8b8;padding:10px 12px 9px}.project-card-name{color:#2c2416;white-space:nowrap;text-overflow:ellipsis;font-family:Georgia,serif;font-size:13px;font-weight:700;overflow:hidden}.project-card-date{color:#999;margin-top:3px;font-family:Georgia,serif;font-size:10px;font-style:italic}.project-card-delete{color:#ffffffd9;cursor:pointer;opacity:0;background:#00000047;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:17px;line-height:1;transition:opacity .15s,background .15s;display:flex;position:absolute;top:7px;right:7px}.project-card:hover .project-card-delete{opacity:1}.project-card-delete:hover{background:#b40000a6!important}.gallery-loading{text-align:center;color:#fff5dca6;padding:48px;font-family:Georgia,serif;font-style:italic}.modal-overlay{z-index:2000;background:#00000085;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-box{background:#fafaf0;border-radius:8px;width:100%;max-width:380px;padding:26px 24px 22px;box-shadow:0 24px 70px #00000073}.modal-title{color:#2c2416;margin-bottom:16px;font-family:Georgia,serif;font-size:20px;font-weight:700}.modal-text{color:#555;margin-bottom:20px;font-family:Georgia,serif;font-size:14px;line-height:1.55}.modal-input{color:#2c2416;background:#fffdf5;border:1.5px solid #d4c49a;border-radius:4px;outline:none;width:100%;padding:10px 12px;font-family:Georgia,serif;font-size:15px;transition:border-color .15s}.modal-input:focus{border-color:#8b0000}.modal-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.btn-cancel{cursor:pointer;color:#666;background:0 0;border:1.5px solid #ccc;border-radius:5px;padding:8px 16px;font-family:Georgia,serif;font-size:14px;transition:border-color .15s}.btn-cancel:hover{border-color:#999}.btn-primary{cursor:pointer;color:#fff;background:#8b0000;border:none;border-radius:5px;padding:8px 22px;font-family:Georgia,serif;font-size:14px;font-weight:700;transition:background .15s}.btn-primary:hover{background:#a50000}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-danger{cursor:pointer;color:#fff;background:#c02000;border:none;border-radius:5px;padding:8px 22px;font-family:Georgia,serif;font-size:14px;font-weight:700;transition:background .15s}.btn-danger:hover{background:#e02500}
