:root{--bg: #F5EDE3;--bg-warm: #F0E6D8;--surface: #FFFFFF;--surface-alt: #FAF6F1;--text: #2C2418;--text-muted: #7A6E5D;--accent: #D4845A;--accent-hover: #C4733F;--border: #E2D9CC;--border-alt: #D6CBBB;--radius: 12px;--font-display: "Instrument Serif", Georgia, serif;--font-body: "DM Sans", sans-serif;--accent-rgb: 212, 132, 90;--layer-amber-rgb: 232, 184, 75;--layer-coral-rgb: 232, 150, 122;--layer-sky-rgb: 124, 184, 212;--layer-sage-rgb: 139, 191, 138;--layer-lavender-rgb: 184, 166, 212;--layer-peach-rgb: 240, 196, 160}*,*:before,*:after{box-sizing:border-box}html{font-size:16px}body{margin:0;font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.65;letter-spacing:.01em;-webkit-font-smoothing:antialiased}.layout{min-height:100vh;display:flex;flex-direction:column;position:relative}.bg-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:var(--bg);overflow:hidden}.bg-layer:before{content:"";position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;will-change:transform;background:radial-gradient(ellipse 80% 60% at 15% 20%,rgba(var(--layer-peach-rgb),.25) 0%,transparent 50%),radial-gradient(ellipse 70% 50% at 85% 75%,rgba(var(--layer-sky-rgb),.18) 0%,transparent 50%),radial-gradient(ellipse 60% 70% at 50% 50%,rgba(var(--layer-amber-rgb),.15) 0%,transparent 55%),radial-gradient(ellipse 55% 45% at 70% 20%,rgba(var(--layer-sage-rgb),.12) 0%,transparent 45%);animation:bgDrift 30s ease-in-out infinite}.bg-layer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;will-change:opacity;background:linear-gradient(160deg,rgba(var(--layer-coral-rgb),.08) 0%,transparent 40%),linear-gradient(340deg,rgba(var(--layer-lavender-rgb),.08) 0%,transparent 40%);animation:bgDriftAlt 25s ease-in-out infinite}@keyframes bgDrift{0%,to{transform:translate(0) scale(1)}33%{transform:translate(2%,1%) scale(1.02)}66%{transform:translate(-1%,2%) scale(.98)}}@keyframes bgDriftAlt{0%,to{opacity:.6}50%{opacity:1}}@media (prefers-reduced-motion: reduce){.bg-layer:before,.bg-layer:after{animation:none}.bg-layer:after{opacity:.8}}.nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#f5ede3d9;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nav-logo{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--text);text-decoration:none;letter-spacing:.02em;transition:color .2s,transform .2s}.nav-logo:hover{color:var(--accent);transform:scale(1.02)}.nav-links{display:flex;gap:.5rem;list-style:none;margin:0;padding:0}.nav-link{padding:.5rem 1rem;color:var(--text-muted);text-decoration:none;border-radius:var(--radius);font-weight:500;transition:color .2s,background .2s,transform .15s}.nav-link:hover{color:var(--text);background:var(--border);transform:translateY(-1px)}.nav-link.active{color:var(--accent);background:rgba(var(--accent-rgb),.15)}.main{flex:1;padding:2rem 1.5rem;max-width:900px;margin:0 auto;width:100%}.page{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header{margin-bottom:2rem}.page-header h1{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,5vw,2.75rem);margin:0 0 .5rem;letter-spacing:-.02em}.page-subtitle{margin:0;color:var(--text-muted);font-size:1.1rem}.main-section{margin-top:2.5rem;padding-top:1.75rem;border-top:1px solid var(--border)}.main-section-title{font-family:var(--font-display);font-weight:700;font-size:1.25rem;margin:0 0 1rem;letter-spacing:-.01em;color:var(--text)}.placeholder-message{color:var(--text-muted);margin:0}.helpful-links-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}.helpful-link-item{display:flex;flex-direction:column;gap:.15rem}.helpful-link-anchor{font-weight:500;color:var(--accent);text-decoration:none;transition:color .2s}.helpful-link-anchor:hover{color:var(--accent-hover);text-decoration:underline}.helpful-link-desc{font-size:.85rem;color:var(--text-muted)}.shortlinks-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.shortlink-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;flex-wrap:wrap}.shortlink-slug{font-weight:600;color:var(--text);text-decoration:none;font-family:var(--font-body)}.shortlink-slug:hover{color:var(--accent)}.shortlink-arrow{color:var(--text-muted);font-size:.8rem}.shortlink-url{color:var(--text-muted);text-decoration:none;word-break:break-all;font-size:.85rem}.shortlink-url:hover{color:var(--accent)}.admin-reorder-buttons{display:flex;flex-direction:column;gap:2px;margin-right:.5rem}.btn-reorder{display:flex;align-items:center;justify-content:center;width:24px;height:20px;padding:0;border:1px solid var(--border);background:var(--surface-alt);color:var(--text-muted);border-radius:4px;cursor:pointer;font-size:.6rem;line-height:1;transition:background .15s,color .15s}.btn-reorder:hover:not(:disabled){background:var(--border);color:var(--text)}.btn-reorder:disabled{opacity:.3;cursor:default}.btn{display:inline-block;padding:.75rem 1.5rem;border-radius:var(--radius);font-weight:600;font-size:.95rem;text-decoration:none;transition:background .2s,color .2s,transform .15s,box-shadow .2s}.btn:hover{transform:translateY(-2px)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 6px 20px rgba(var(--accent-rgb),.4)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border);border-color:var(--text-muted)}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem}.card-wrapper{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:1.15rem;transition:border-color .25s,transform .25s ease,box-shadow .25s ease}.card-wrapper:hover{border-color:var(--accent);transform:translateY(-6px);box-shadow:0 8px 20px rgba(var(--accent-rgb),.12),0 2px 6px #0000000f}.card{display:flex;flex-direction:column;height:100%;text-decoration:none;color:inherit}.card:hover{text-decoration:none;color:inherit}.card-image{margin:-1.15rem -1.15rem .85rem;border-radius:16px 16px 0 0;overflow:hidden;aspect-ratio:16/10;background:var(--border)}.card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.card-wrapper:hover .card-image img{transform:scale(1.04)}.card-body{display:flex;flex-direction:column;flex:1;padding:0}.card-title{font-family:var(--font-display);font-weight:600;font-size:1.1rem;line-height:1.3;margin:0 0 .4rem;color:var(--text)}.card-description{margin:0 0 auto;padding-bottom:.65rem;font-size:.82rem;color:var(--text-muted);line-height:1.5}.card-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:auto;padding-top:.65rem;border-top:1px solid var(--border)}.card-tags{display:flex;flex-wrap:wrap;gap:.4rem;list-style:none;margin:0;padding:0}.card-tag{font-size:.68rem;font-weight:500;letter-spacing:.02em;padding:.2rem .55rem;background:rgba(var(--accent-rgb),.1);color:var(--accent);border-radius:20px}.card-arrow{font-size:1.1rem;color:var(--border-alt);transition:color .2s,transform .2s;margin-left:auto;flex-shrink:0}.card-wrapper:hover .card-arrow{color:var(--accent);transform:translate(2px,-2px)}.share-app-menu{position:absolute;bottom:.85rem;right:.85rem;z-index:2;opacity:0;transition:opacity .2s}.card-wrapper:hover .share-app-menu{opacity:1}.card-share-trigger{display:flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;color:var(--text-muted);background:var(--surface-alt);border:1px solid var(--border);border-radius:50%;cursor:pointer;transition:color .2s,background .2s,border-color .2s}.card-share-trigger:hover{color:#fff;background:var(--accent);border-color:var(--accent)}.share-app-dropdown{position:absolute;bottom:100%;right:0;margin-bottom:.35rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.5rem;min-width:120px;box-shadow:0 8px 24px #0000001a;z-index:20}.share-app-dropdown .share-option{display:block;width:100%;padding:.5rem .75rem;text-align:left;border:none;background:none;color:var(--text);font:inherit;cursor:pointer;border-radius:6px;transition:background .15s}.share-app-dropdown .share-option:hover{background:var(--border)}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);color:var(--text-muted);position:relative}.auth-loading:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(ellipse 70% 50% at 50% 40%,rgba(var(--layer-amber-rgb),.15) 0%,transparent 50%)}.auth-loading.auth-denied{flex-direction:column;gap:1rem}.auth-denied p{margin:0}.firebase-config-title{font-family:var(--font-display);font-weight:600;margin:0 0 .5rem}.firebase-config-message{margin:0 0 1rem;color:#e08080;max-width:420px}.firebase-config-hint{margin:0;font-size:.9rem;color:var(--text-muted);max-width:480px;line-height:1.5}.firebase-config-hint code{background:var(--border);padding:.15rem .4rem;border-radius:4px;font-size:.85em}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:1.5rem;position:relative}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(ellipse 80% 60% at 30% 50%,rgba(var(--layer-peach-rgb),.2) 0%,transparent 55%),radial-gradient(ellipse 60% 40% at 70% 30%,rgba(var(--layer-sky-rgb),.15) 0%,transparent 50%)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem;max-width:360px;width:100%;text-align:center}.login-title{font-family:var(--font-display);font-weight:700;font-size:1.75rem;margin:0 0 .5rem}.login-subtitle{margin:0 0 1.5rem;color:var(--text-muted);font-size:.95rem}.btn-google{background:var(--text);color:var(--bg);border:1px solid var(--border-alt);cursor:pointer;font-family:var(--font-body)}.btn-google:hover{background:var(--text-muted);border-color:var(--border-alt)}.btn-sm{padding:.4rem .9rem;font-size:.85rem}.btn-danger{background:#dc505026;color:#e08080;border:1px solid rgba(220,80,80,.4)}.btn-danger:hover{background:#dc505040;border-color:#e08080}.share-menu{position:relative}.share-trigger{border:none;background:none;cursor:pointer;font:inherit}.share-dropdown{position:absolute;top:100%;right:0;margin-top:.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.5rem;min-width:140px;box-shadow:0 8px 24px #0000001a;z-index:20}.share-option{display:block;width:100%;padding:.5rem .75rem;text-align:left;border:none;background:none;color:var(--text);font:inherit;cursor:pointer;border-radius:6px;transition:background .15s}.share-option:hover{background:var(--border)}.admin-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:1px solid var(--border)}.admin-tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font:inherit;font-weight:500;cursor:pointer;transition:color .2s,border-color .2s;margin-bottom:-1px}.admin-tab:hover{color:var(--text)}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-home-section{margin-bottom:3rem}.admin-section-title{font-family:var(--font-display);font-weight:600;font-size:1.25rem;margin:0 0 1.5rem;color:var(--text)}.admin-form{margin-bottom:2.5rem;padding:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-width:480px}.admin-form-title,.admin-list-title{font-family:var(--font-display);font-weight:600;font-size:1.1rem;margin:0 0 1rem}.admin-form label{display:block;margin-bottom:1rem;font-size:.9rem;color:var(--text-muted)}.admin-form label input,.admin-form label textarea,.admin-form label select{display:block;width:100%;margin-top:.35rem;padding:.6rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font:inherit}.admin-form label textarea{resize:vertical;min-height:100px;font-family:var(--font-body)}.admin-form label input:focus,.admin-form label textarea:focus,.admin-form label select:focus{outline:none;border-color:var(--accent)}.admin-checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.admin-checkbox-label input[type=checkbox]{width:auto;margin:0;cursor:pointer}.admin-form-actions{display:flex;gap:.75rem;margin-top:.5rem}.admin-form .required{color:var(--accent)}.admin-form .hint{font-weight:400;opacity:.8}.admin-form .btn{margin-top:.5rem}.admin-list-title{margin-bottom:1rem}.admin-items{list-style:none;margin:0;padding:0}.admin-item{padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.75rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.admin-item-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.admin-item-info p{margin:.25rem 0 0;color:var(--text-muted);font-size:.9rem}.admin-item-meta{font-size:.85rem;color:var(--text-muted)}.admin-badge{display:inline-block;padding:.2rem .5rem;background:var(--accent);color:#fff;font-size:.75rem;font-weight:600;border-radius:4px;margin-left:.5rem}.admin-item-url{font-size:.85rem;color:var(--text-muted);word-break:break-all}.admin-item-url:hover{color:var(--accent)}.admin-item-actions{display:flex;gap:.5rem}.admin-edit-form{width:100%;display:grid;gap:.5rem}.admin-edit-form input{padding:.5rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font:inherit}.admin-edit-actions{display:flex;gap:.5rem;margin-top:.5rem}.admin-error{color:#e08080;margin:0}.admin-empty{color:var(--text-muted);margin:0}.admin-loading-slow{margin-top:1rem;font-size:.9rem;color:var(--text-muted);max-width:520px;line-height:1.5}.admin-loading-slow code{background:var(--border);padding:.15rem .4rem;border-radius:4px;font-size:.85em}.admin-error-code{margin:.5rem 0 0;font-size:.9rem;color:var(--text-muted)}.portfolio-loading,.portfolio-error,.portfolio-empty{margin:0 0 1rem;color:var(--text-muted)}.portfolio-error{color:#e08080}
