/* Memory Jars — styles.css v3.0
   @luminabom | luminabom.portfolio */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --cream:#FDF8F0;--warm-white:#FFFCF5;
  --amber-light:#FDE8C0;--amber:#E8A427;--amber-dark:#C07B12;
  --brown-light:#D4A96A;--brown:#8B5E3C;--brown-dark:#5C3820;
  --text-dark:#2C1A0E;--text-mid:#6B4226;--text-muted:#A07850;
  --shadow:rgba(90,50,20,.13);--shelf:#C49A6C;--shelf-dark:#A07040;
  --danger:#C0392B;--danger-light:#FDE8E8;--success:#27AE60;
  --info-bg:#EFF8FF;--info-border:#90CAF9;--info-text:#1565C0;
  --sidebar-w:260px;--header-h:54px;
  --r-sm:8px;--r-md:12px;--r-lg:18px;--r-xl:24px;
  --ease:cubic-bezier(.34,1.56,.64,1);--ease-out:cubic-bezier(.25,.46,.45,.94);
}
@media(min-width:768px){:root{--header-h:60px;}}
@media(min-width:1280px){:root{--sidebar-w:280px;}}

/* ── BASE ── */
html,body{max-width:100vw;overflow-x:hidden;}
body{font-family:'Lato','Sarabun',sans-serif;background:var(--cream);color:var(--text-dark);min-height:100vh;}
body::before{content:'';position:fixed;inset:0;background-image:radial-gradient(circle at 20px 20px,rgba(200,150,80,.055) 1px,transparent 1px),radial-gradient(circle at 60px 60px,rgba(200,150,80,.038) 1px,transparent 1px);background-size:80px 80px;pointer-events:none;z-index:0;}

/* ── SHELL ── */
#app-shell{position:relative;z-index:1;display:grid;min-height:100vh;width:100%;max-width:100%;grid-template-columns:1fr;grid-template-rows:var(--header-h) 1fr;grid-template-areas:"header" "main";}
@media(min-width:768px){#app-shell{grid-template-columns:var(--sidebar-w) 1fr;grid-template-areas:"header header" "sidebar main";}}

/* ── HEADER ── */
#top-header{grid-area:header;background:linear-gradient(135deg,var(--brown-dark) 0%,var(--brown) 100%);border-bottom:3px solid var(--amber);display:flex;align-items:center;padding:0 12px;gap:10px;position:sticky;top:0;z-index:50;box-shadow:0 2px 12px rgba(44,26,14,.25);width:100%;max-width:100%;min-width:0;overflow:hidden;}
.header-logo{font-family:'Playfair Display','Sarabun',serif;font-size:1.2rem;font-weight:600;color:var(--amber-light);white-space:nowrap;flex-shrink:0;}
.header-logo em{font-style:italic;color:var(--amber);}
@media(min-width:768px){.header-logo{font-size:1.38rem;}}
.header-spacer{flex:1;min-width:0;}
.header-user{display:flex;align-items:center;gap:7px;flex-shrink:0;}
.header-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;color:#fff;border:2px solid rgba(255,220,160,.5);flex-shrink:0;text-transform:uppercase;}
.header-username{font-size:.75rem;font-weight:700;color:var(--amber-light);max-width:75px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.header-login-btn{background:var(--amber-dark);color:#fff;border:none;border-radius:18px;padding:5px 11px;font-size:.74rem;font-weight:700;cursor:pointer;font-family:'Lato',sans-serif;transition:background .15s;white-space:nowrap;}
.header-login-btn:hover{background:var(--amber);}
.lang-switcher{display:none;gap:3px;flex-shrink:0;}
@media(min-width:768px){.lang-switcher{display:flex;}}
.lang-btn{padding:3px 8px;border-radius:12px;font-size:.66rem;font-weight:700;cursor:pointer;border:1px solid rgba(255,220,160,.3);background:transparent;color:rgba(255,220,160,.7);transition:all .15s;font-family:'Lato','Sarabun',sans-serif;}
.lang-btn.active{background:var(--amber-dark);color:#fff;border-color:var(--amber-dark);}
.lang-btn:hover:not(.active){background:rgba(255,255,255,.1);color:#fff;}
.mobile-lang-row{display:flex;gap:5px;padding:10px 0 4px;flex-wrap:wrap;}
.mobile-lang-row .lang-btn{font-size:.71rem;padding:5px 10px;}
@media(min-width:768px){.mobile-lang-row{display:none;}}

/* ── SIDEBAR ── */
#sidebar{grid-area:sidebar;display:none;background:var(--warm-white);border-right:1px solid var(--amber-light);flex-direction:column;padding:16px 0;position:sticky;top:var(--header-h);height:calc(100vh - var(--header-h));overflow-y:auto;min-width:0;}
@media(min-width:768px){#sidebar{display:flex;}}
.sidebar-section{padding:0 12px;margin-bottom:5px;}
.sidebar-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);padding:6px 7px 3px;}
.sidebar-btn{display:flex;align-items:center;gap:8px;width:100%;padding:7px 8px;border-radius:var(--r-sm);border:none;background:transparent;color:var(--text-mid);font-family:'Lato','Sarabun',sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;text-align:left;transition:background .15s,color .15s;}
.sidebar-btn .icon{font-size:.88rem;width:18px;text-align:center;}
.sidebar-btn:hover{background:var(--amber-light);color:var(--brown-dark);}
.sidebar-btn.active{background:var(--amber-light);color:var(--brown-dark);}
.sidebar-btn.primary{background:var(--amber-dark);color:#fff;margin-bottom:3px;}
.sidebar-btn.primary:hover{background:var(--amber);}
.sidebar-sort-val{margin-left:auto;font-size:.65rem;color:var(--text-muted);font-weight:400;}
.sidebar-divider{height:1px;background:var(--amber-light);margin:6px 12px;}
.sidebar-stats{padding:8px 12px;margin-top:auto;border-top:1px solid var(--amber-light);}
.sidebar-stat-row{display:flex;justify-content:space-between;font-size:.73rem;color:var(--text-muted);padding:2px 0;}
.sidebar-stat-row strong{color:var(--amber-dark);font-weight:700;}
.sidebar-creator{padding:8px 12px 6px;font-size:.65rem;color:var(--text-muted);border-top:1px solid var(--amber-light);margin-top:6px;line-height:1.6;}
.sidebar-creator a{color:var(--amber-dark);text-decoration:none;}
.sidebar-creator a:hover{text-decoration:underline;}

/* ── MAIN ── */
#main-content{grid-area:main;min-width:0;width:100%;max-width:100%;overflow-x:hidden;padding:12px 12px 80px;}
@media(min-width:768px){#main-content{padding:20px 22px 60px;overflow-y:auto;max-height:calc(100vh - var(--header-h));}}
@media(min-width:1280px){#main-content{padding:22px 28px 60px;}}

/* ── PRIVACY NOTICE ── */
.privacy-notice{background:var(--info-bg);border:1px solid var(--info-border);border-radius:var(--r-md);padding:10px 13px;margin-bottom:14px;display:flex;align-items:flex-start;gap:8px;width:100%;box-sizing:border-box;}
.pn-icon{font-size:.9rem;flex-shrink:0;margin-top:2px;}
.privacy-notice p{font-size:.73rem;color:var(--info-text);line-height:1.55;flex:1;min-width:0;}
.privacy-notice p strong{font-weight:700;}
.pn-dismiss{background:none;border:none;cursor:pointer;color:var(--info-text);font-size:.8rem;padding:0 0 0 5px;flex-shrink:0;opacity:.55;line-height:1;align-self:flex-start;}
.pn-dismiss:hover{opacity:1;}

/* ── PAGE HEADER with SEARCH ── */
.page-header{margin-bottom:20px;}
.page-title-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.page-title{font-family:'Playfair Display','Sarabun',serif;font-size:1.4rem;font-weight:600;font-style:italic;color:var(--brown-dark);flex:1;min-width:0;}
@media(min-width:768px){.page-title{font-size:1.65rem;}}
.page-header-actions{display:flex;gap:8px;align-items:center;flex-shrink:0;}
.sort-pill{background:var(--warm-white);border:1.5px solid var(--brown-light);color:var(--text-mid);border-radius:20px;padding:6px 13px;font-size:.76rem;font-weight:700;cursor:pointer;font-family:'Lato','Sarabun',sans-serif;transition:background .15s;white-space:nowrap;}
.sort-pill:hover{background:var(--amber-light);}
/* Hide sort pill on desktop (sidebar has it) */
@media(min-width:768px){.sort-pill{display:none;}}
.ph-new-btn{background:var(--amber-dark);color:#fff;border:none;border-radius:50%;width:36px;height:36px;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 12px rgba(192,123,18,.3);transition:background .15s,transform .15s;flex-shrink:0;}
.ph-new-btn:hover{background:var(--amber);transform:scale(1.08);}
@media(min-width:768px){.ph-new-btn{display:none;}} /* sidebar has + button */

/* ── INLINE SEARCH BAR ── */
.inline-search-wrap{display:flex;align-items:center;gap:8px;background:var(--warm-white);border:1.5px solid var(--brown-light);border-radius:30px;padding:8px 14px;box-shadow:0 2px 8px var(--shadow);transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box;}
.inline-search-wrap:focus-within{border-color:var(--amber-dark);box-shadow:0 2px 12px rgba(192,123,18,.18);}
.search-icon{font-size:.9rem;flex-shrink:0;color:var(--text-muted);}
.inline-search{flex:1;min-width:0;border:none;background:transparent;font-family:'Lato','Sarabun',sans-serif;font-size:.88rem;color:var(--text-dark);outline:none;}
.inline-search::placeholder{color:var(--text-muted);}
.inline-search-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.88rem;padding:2px;flex-shrink:0;opacity:.6;}
.inline-search-clear:hover{opacity:1;}

/* ── NO JARS MSG ── */
.no-jars-msg{text-align:center;color:var(--text-muted);font-style:italic;padding:40px 0;font-family:'Playfair Display','Sarabun',serif;}

/* ── MOBILE TOOLBAR ── */
.mobile-toolbar{position:fixed;bottom:0;left:0;right:0;background:var(--warm-white);border-top:1px solid var(--amber-light);display:flex;align-items:center;justify-content:space-around;padding:7px 8px calc(7px + env(safe-area-inset-bottom));z-index:40;box-shadow:0 -2px 12px rgba(44,26,14,.1);}
@media(min-width:768px){.mobile-toolbar{display:none;}}
.mob-btn{display:flex;flex-direction:column;align-items:center;gap:1px;background:none;border:none;cursor:pointer;color:var(--text-mid);font-family:'Lato',sans-serif;padding:3px 9px;border-radius:8px;transition:background .15s;}
.mob-btn:hover,.mob-btn.active{background:var(--amber-light);color:var(--brown-dark);}
.mob-icon{font-size:1.1rem;line-height:1;}
.mob-label{font-size:.55rem;font-weight:700;letter-spacing:.2px;}
.mob-btn-new{background:var(--amber-dark);color:#fff;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.3rem;border:none;cursor:pointer;box-shadow:0 4px 14px rgba(192,123,18,.35);transition:background .15s,transform .15s;flex-shrink:0;}
.mob-btn-new:hover{background:var(--amber);transform:scale(1.08);}

/* ── SHELF ── */
.shelf-block{margin-bottom:30px;}
.shelf-header{display:flex;align-items:center;gap:7px;margin-bottom:6px;}
.shelf-name{font-family:'Playfair Display','Sarabun',serif;font-size:.94rem;font-style:italic;color:var(--text-muted);flex:1;min-width:0;}
.shelf-action{background:none;border:none;cursor:pointer;font-size:.72rem;padding:3px 6px;border-radius:7px;transition:background .12s;}
.shelf-action.edit{color:var(--text-muted);}.shelf-action.edit:hover{background:var(--amber-light);color:var(--brown-dark);}
.shelf-action.del{color:rgba(192,57,43,.5);}.shelf-action.del:hover{background:var(--danger-light);color:var(--danger);}
.shelf-surface{background:linear-gradient(180deg,var(--shelf) 0,var(--shelf) 16px,var(--shelf-dark) 16px,var(--shelf-dark) 22px,transparent 22px);border-radius:4px;padding:20px 12px 4px;min-height:150px;box-shadow:0 6px 18px rgba(90,50,20,.17),inset 0 1px 0 rgba(255,220,160,.4);overflow:hidden;width:100%;box-sizing:border-box;}
.jars-row{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;padding-bottom:10px;width:100%;min-width:0;}
@media(min-width:480px){.jars-row{gap:13px;}}
@media(min-width:768px){.jars-row{gap:17px;}}
@media(min-width:1280px){.jars-row{gap:20px;}}
.empty-shelf{color:var(--text-muted);font-size:.8rem;font-style:italic;padding:12px 0 18px;}

/* ── JAR CARD ── */
.jar-card{display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .2s var(--ease);position:relative;user-select:none;flex-shrink:0;width:72px;}
@media(min-width:480px){.jar-card{width:80px;}}
@media(min-width:768px){.jar-card{width:92px;}}
@media(min-width:1024px){.jar-card{width:104px;}}
@media(min-width:1280px){.jar-card{width:116px;}}
.jar-card:hover{transform:translateY(-5px) rotate(-.7deg);}
.jar-svg-wrap{position:relative;width:100%;}
.jar-svg{display:block;width:100%;height:auto;filter:drop-shadow(0 5px 9px rgba(90,50,20,.22));}
/* Hover bubble */
.jar-bubble{display:none;position:absolute;right:-108px;top:5px;width:100px;background:#FFFDE7;border-radius:4px 10px 10px 4px;padding:6px 8px;font-family:'Playfair Display','Sarabun',serif;font-size:.58rem;line-height:1.45;color:#5C4A00;font-style:italic;box-shadow:2px 3px 10px rgba(90,50,10,.14);border-left:3px solid #F0C040;z-index:20;pointer-events:none;}
.jar-bubble::before{content:'';position:absolute;left:-7px;top:11px;border:6px solid transparent;border-right-color:#F0C040;}
@media(min-width:900px){.jar-card:hover .jar-bubble{display:block;}}
.jar-name{font-family:'Playfair Display','Sarabun',serif;font-size:.68rem;font-weight:600;color:var(--brown-dark);margin-top:5px;text-align:center;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.jar-count{font-size:.6rem;color:var(--text-muted);margin-top:1px;}
.jar-tags{display:flex;gap:3px;flex-wrap:wrap;justify-content:center;margin-top:3px;width:100%;}
.jar-tag{font-size:.5rem;font-weight:700;padding:1px 5px;border-radius:6px;white-space:nowrap;}
.jar-tag.featured{background:#E3F2FD;color:#1565C0;border:1px solid #90CAF9;}
.jar-tag.new-tag{background:#E8F5E9;color:#2E7D32;border:1px solid #A5D6A7;}
.jar-tag.ig{background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045);color:#fff;}
.jar-tag.thai{background:#F3E5F5;color:#6A1B9A;border:1px solid #CE93D8;}
.jar-tag.cat{background:var(--amber-light);color:var(--brown-dark);}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:5px;padding:8px 16px;border-radius:28px;font-family:'Lato','Sarabun',sans-serif;font-size:.83rem;font-weight:700;letter-spacing:.3px;cursor:pointer;transition:transform .15s,box-shadow .15s,background .15s;border:none;}
.btn:active{transform:scale(.97);}
.btn-primary{background:var(--amber-dark);color:#fff;box-shadow:0 4px 14px rgba(192,123,18,.28);}
.btn-primary:hover{background:var(--amber);box-shadow:0 6px 20px rgba(192,123,18,.4);transform:translateY(-1px);}
.btn-secondary{background:var(--warm-white);color:var(--brown-dark);border:1.5px solid var(--brown-light);box-shadow:0 2px 8px var(--shadow);}
.btn-secondary:hover{background:var(--amber-light);transform:translateY(-1px);}
.btn-danger{background:var(--danger);color:#fff;}.btn-danger:hover{background:#a93226;}
.btn-ghost{background:none;border:1.5px solid var(--brown-light);color:var(--text-mid);}.btn-ghost:hover{background:var(--amber-light);}
.btn-sm{padding:5px 12px;font-size:.76rem;}.btn-xs{padding:3px 9px;font-size:.7rem;}

/* ── MODALS ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(44,26,14,.52);z-index:200;align-items:flex-end;justify-content:center;padding:0;backdrop-filter:blur(4px);}
.modal-overlay.open{display:flex;}
.modal{background:var(--warm-white);border-radius:var(--r-lg) var(--r-lg) 0 0;width:100%;max-width:100%;max-height:92vh;overflow-y:auto;box-shadow:0 -8px 40px rgba(44,26,14,.28);animation:slideUp .24s var(--ease-out);}
@keyframes slideUp{from{transform:translateY(40px);opacity:.7;}to{transform:translateY(0);opacity:1;}}
@media(min-width:600px){.modal-overlay{align-items:center;padding:16px;}.modal{border-radius:var(--r-lg);max-width:640px;box-shadow:0 24px 60px rgba(44,26,14,.3);animation:popIn .22s var(--ease);}@keyframes popIn{from{transform:scale(.88);opacity:0;}to{transform:scale(1);opacity:1;}}}
.modal-sm{max-width:420px;}.modal-xs{max-width:330px;}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:13px 16px 11px;border-bottom:1px solid var(--amber-light);position:sticky;top:0;background:var(--warm-white);z-index:2;border-radius:var(--r-lg) var(--r-lg) 0 0;gap:8px;}
.modal-title{font-family:'Playfair Display','Sarabun',serif;font-size:1.15rem;font-style:italic;color:var(--brown-dark);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.modal-header-actions{display:flex;gap:6px;align-items:center;flex-shrink:0;}
.close-btn{width:27px;height:27px;border-radius:50%;border:1.5px solid var(--brown-light);background:transparent;cursor:pointer;font-size:.85rem;color:var(--text-mid);display:flex;align-items:center;justify-content:center;transition:background .15s;}
.close-btn:hover{background:var(--amber-light);}
.modal-body{padding:13px 16px 18px;}
.modal-footer{padding:10px 16px 16px;display:flex;gap:7px;flex-wrap:wrap;align-items:center;border-top:1px solid var(--amber-light);}

/* Auth modal always centered */
#auth-modal{align-items:center;padding:16px;}
#auth-modal .modal{border-radius:var(--r-xl)!important;max-width:370px!important;animation:popIn .25s var(--ease)!important;}

/* ── AUTH CARD ── */
.auth-card{padding:24px 22px 18px;}
.auth-logo{font-family:'Playfair Display',serif;font-size:1.7rem;font-weight:600;color:var(--brown-dark);text-align:center;margin-bottom:4px;}
.auth-logo em{font-style:italic;color:var(--amber-dark);}
.auth-subtitle{text-align:center;font-size:.76rem;color:var(--text-muted);margin-bottom:18px;}
.auth-toggle{text-align:center;font-size:.76rem;color:var(--text-muted);margin-top:12px;}
.auth-toggle a{color:var(--amber-dark);cursor:pointer;font-weight:700;text-decoration:none;}
.auth-toggle a:hover{text-decoration:underline;}
.auth-guest-link{text-align:center;margin-top:8px;font-size:.72rem;color:var(--text-muted);cursor:pointer;text-decoration:underline;}

/* ── FORMS ── */
.form-row{margin-bottom:10px;}
.form-row label{display:block;font-size:.72rem;color:var(--text-mid);margin-bottom:3px;font-weight:700;letter-spacing:.3px;}
.form-row input[type=text],.form-row input[type=password],.form-row input[type=date],.form-row textarea,.form-row select{width:100%;max-width:100%;padding:8px 10px;border-radius:var(--r-sm);border:1.5px solid var(--brown-light);background:var(--cream);font-family:'Lato','Sarabun',sans-serif;font-size:.87rem;color:var(--text-dark);resize:vertical;outline:none;transition:border-color .15s,box-shadow .15s;}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{border-color:var(--amber-dark);box-shadow:0 0 0 3px rgba(192,123,18,.1);}
.form-hint{font-size:.68rem;color:var(--text-muted);margin-top:3px;}
.form-hint.ok{color:var(--success);}.form-hint.err{color:var(--danger);}
.form-row-inline{display:flex;gap:9px;}.form-row-inline .form-row{flex:1;min-width:0;}
.pin-display{display:flex;gap:8px;margin:8px 0;justify-content:center;}
.pin-dot{width:12px;height:12px;border-radius:50%;background:var(--brown-light);transition:background .15s;}
.pin-dot.filled{background:var(--amber-dark);}
.tags-input-wrap{display:flex;flex-wrap:wrap;gap:5px;align-items:center;padding:6px 9px;border-radius:var(--r-sm);border:1.5px solid var(--brown-light);background:var(--cream);cursor:text;transition:border-color .15s;max-width:100%;}
.tags-input-wrap:focus-within{border-color:var(--amber-dark);}
.tags-input-wrap input{border:none;background:transparent;outline:none;font-family:'Lato','Sarabun',sans-serif;font-size:.84rem;flex:1;min-width:60px;padding:0;}
.tag-chip{background:var(--amber-light);color:var(--brown-dark);font-size:.7rem;font-weight:700;padding:2px 7px;border-radius:9px;display:flex;align-items:center;gap:3px;}
.tag-chip button{background:none;border:none;cursor:pointer;color:var(--brown);font-size:.62rem;padding:0;line-height:1;}

/* ── JAR MODAL CONTENT ── */
.jar-desc-line{font-size:.8rem;color:var(--text-muted);font-style:italic;margin-bottom:8px;}
.jar-note-full{background:#FFFDE7;border-left:3px solid #F0C040;border-radius:4px;padding:8px 11px;margin-bottom:11px;font-family:'Playfair Display','Sarabun',serif;font-size:.81rem;font-style:italic;color:#5C4A00;}
.showcase-note{text-align:center;padding:10px 0 4px;color:var(--text-muted);font-style:italic;font-size:.82rem;}
.showcase-note a{color:var(--amber-dark);cursor:pointer;font-weight:700;}
.mem-filter-bar{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap;}
.mem-chip{padding:4px 11px;border-radius:17px;font-size:.72rem;font-weight:700;cursor:pointer;border:1.5px solid var(--brown-light);background:transparent;color:var(--text-mid);transition:background .15s;font-family:'Lato','Sarabun',sans-serif;}
.mem-chip.active{background:var(--amber-dark);color:#fff;border-color:var(--amber-dark);}
.mem-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(105px,1fr));gap:8px;margin-bottom:12px;}
.mem-card{border-radius:var(--r-md);overflow:hidden;border:1.5px solid var(--amber-light);background:var(--cream);position:relative;cursor:pointer;transition:transform .15s,box-shadow .15s;}
.mem-card:hover{transform:scale(1.03);box-shadow:0 6px 18px var(--shadow);}
.mem-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block;}
.mem-card .note-body{padding:10px;font-size:.75rem;line-height:1.5;color:var(--text-dark);font-family:'Playfair Display','Sarabun',serif;font-style:italic;aspect-ratio:1;display:flex;align-items:center;background:linear-gradient(135deg,#FFFDF5 0%,#FFF5DC 100%);overflow:hidden;}
.mem-card .note-body span{overflow:hidden;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;}
.mem-del{position:absolute;top:5px;right:5px;width:20px;height:20px;border-radius:50%;background:rgba(44,26,14,.65);color:#fff;border:none;cursor:pointer;font-size:.65rem;align-items:center;justify-content:center;display:none;}
.mem-card:hover .mem-del{display:flex;}
.mem-badge{position:absolute;bottom:5px;left:5px;background:rgba(44,26,14,.55);color:#fff;font-size:.53rem;padding:2px 6px;border-radius:6px;text-transform:uppercase;letter-spacing:.4px;font-family:'Lato',sans-serif;max-width:76px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.mem-date-badge{position:absolute;top:5px;left:5px;background:rgba(255,252,240,.86);color:var(--text-mid);font-size:.52rem;padding:2px 6px;border-radius:6px;font-family:'Lato',sans-serif;}
.mem-mood{position:absolute;top:5px;right:25px;font-size:.85rem;}
.empty-jar-msg{text-align:center;padding:22px 0;color:var(--text-muted);font-style:italic;font-family:'Playfair Display','Sarabun',serif;font-size:.88rem;}

/* ── ADD MEMORY FORM ── */
.add-mem-form{border-top:1px solid var(--amber-light);padding-top:13px;margin-top:6px;}
.add-mem-form h3{font-family:'Playfair Display','Sarabun',serif;font-size:.88rem;color:var(--brown);margin-bottom:10px;font-style:italic;}
.tab-row{display:flex;border:1.5px solid var(--brown-light);border-radius:9px;overflow:hidden;margin-bottom:10px;width:fit-content;}
.tab-btn{padding:5px 14px;font-family:'Lato','Sarabun',sans-serif;font-size:.77rem;font-weight:700;cursor:pointer;border:none;background:transparent;color:var(--text-muted);transition:background .15s,color .15s;}
.tab-btn.active{background:var(--amber-dark);color:#fff;}
.tab-panel{display:none;}.tab-panel.active{display:block;}

/* ── UPLOAD ZONE ── */
.upload-zone{border:2px dashed var(--brown-light);border-radius:var(--r-md);padding:16px;text-align:center;cursor:pointer;transition:background .15s,border-color .15s;background:var(--cream);}
.upload-zone:hover{background:var(--amber-light);border-color:var(--amber-dark);}
.upload-zone input{display:none;}
.upload-icon{font-size:1.5rem;margin-bottom:3px;}
.upload-zone p{font-size:.74rem;color:var(--text-muted);}
.upload-zone-sm{padding:10px;}
.photo-previews{display:grid;grid-template-columns:repeat(4,1fr);gap:5px;margin-top:7px;}
.prev-thumb{position:relative;cursor:pointer;}
.prev-thumb img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;display:block;}
.prev-thumb::after{content:'✕';position:absolute;top:3px;right:3px;background:rgba(44,26,14,.7);color:#fff;border-radius:50%;width:16px;height:16px;display:grid;place-items:center;font-size:.57rem;}

/* ── COLOR / ICON PICKERS ── */
.color-swatches{display:flex;gap:7px;flex-wrap:wrap;margin-top:4px;}
.swatch{width:25px;height:25px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:transform .12s,border-color .12s;}
.swatch:hover{transform:scale(1.18);}.swatch.selected{border-color:var(--brown-dark);}
.icon-picker{display:flex;gap:5px;flex-wrap:wrap;margin-top:4px;}
.icon-opt{font-size:1.25rem;cursor:pointer;padding:2px;border-radius:6px;border:2px solid transparent;transition:border-color .12s;line-height:1;}
.icon-opt:hover{border-color:var(--brown-light);}.icon-opt.selected{border-color:var(--brown-dark);}
.icon-none{font-size:.63rem;cursor:pointer;padding:3px 8px;border-radius:6px;border:1.5px solid var(--brown-light);color:var(--text-muted);}

/* ── CATEGORY MODAL ── */
.cat-list{list-style:none;}
.cat-list li{display:flex;align-items:center;gap:7px;padding:7px 9px;border-radius:9px;margin-bottom:3px;background:var(--cream);border:1px solid var(--amber-light);}
.cat-list li .cat-n{flex:1;font-size:.85rem;color:var(--text-dark);}
.cat-new-row{display:flex;gap:7px;margin-top:9px;}
.cat-new-row input{flex:1;min-width:0;padding:7px 10px;border-radius:var(--r-sm);border:1.5px solid var(--brown-light);background:var(--cream);font-family:'Lato','Sarabun',sans-serif;font-size:.85rem;outline:none;}

/* ── CONFIRM ── */
.confirm-box{background:var(--warm-white);border-radius:var(--r-lg);padding:22px 20px 16px;max-width:310px;width:100%;box-shadow:0 20px 50px rgba(44,26,14,.28);animation:popIn .22s var(--ease);}
.confirm-box h3{font-family:'Playfair Display','Sarabun',serif;font-size:1rem;color:var(--brown-dark);margin-bottom:6px;}
.confirm-box p{font-size:.82rem;color:var(--text-muted);margin-bottom:14px;}
.confirm-box .btn-row{display:flex;gap:7px;justify-content:flex-end;}
#confirm-modal{align-items:center;padding:16px;}

/* ── EXPORT MENU ── */
.export-wrap{position:relative;}
.export-menu{position:absolute;top:calc(100% + 4px);left:0;background:var(--warm-white);border:1.5px solid var(--brown-light);border-radius:var(--r-md);padding:4px 0;box-shadow:0 8px 24px var(--shadow);min-width:130px;z-index:60;display:none;}
.export-menu.open{display:block;}
.export-item{padding:7px 13px;font-size:.78rem;cursor:pointer;color:var(--text-dark);background:none;border:none;width:100%;text-align:left;font-family:'Lato','Sarabun',sans-serif;transition:background .12s;}
.export-item:hover{background:var(--amber-light);}

/* ── LIGHTBOX ── */
#lightbox{display:none;position:fixed;inset:0;background:rgba(20,10,4,.93);z-index:300;align-items:center;justify-content:center;cursor:zoom-out;}
#lightbox.open{display:flex;}
#lightbox img{max-width:90vw;max-height:85vh;border-radius:5px;}
#lb-cap{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);background:rgba(255,252,240,.92);color:var(--text-dark);padding:5px 14px;border-radius:17px;font-size:.8rem;font-family:'Playfair Display','Sarabun',serif;font-style:italic;max-width:80vw;text-align:center;}

/* ── CONTEXT MENU ── */
.fctx{position:fixed;background:var(--warm-white);border:1.5px solid var(--brown-light);border-radius:var(--r-md);padding:5px 0;box-shadow:0 8px 24px var(--shadow);z-index:500;min-width:142px;}
.fctx button{display:block;width:100%;padding:8px 14px;font-size:.78rem;cursor:pointer;color:var(--text-dark);background:none;border:none;text-align:left;font-family:'Lato','Sarabun',sans-serif;transition:background .12s;}
.fctx button:hover{background:var(--amber-light);}
.fctx button.danger{color:var(--danger);}.fctx button.danger:hover{background:var(--danger-light);}

/* ── TOAST ── */
#toast{position:fixed;bottom:68px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--brown-dark);color:#fff;padding:8px 18px;border-radius:26px;font-size:.82rem;z-index:400;transition:transform .3s var(--ease-out),opacity .3s;opacity:0;pointer-events:none;white-space:nowrap;max-width:88vw;overflow:hidden;text-overflow:ellipsis;}
#toast.show{transform:translateX(-50%) translateY(0);opacity:1;}
@media(min-width:768px){#toast{bottom:24px;}}

/* ── FOOTER ── */
.portfolio-footer{margin-top:36px;border-top:2px solid var(--amber-light);padding-top:20px;text-align:center;}
.pf-logo{font-family:'Playfair Display',serif;font-size:1.25rem;font-style:italic;font-weight:600;color:var(--brown-dark);margin-bottom:5px;}
.pf-logo em{color:var(--amber-dark);}
.pf-desc{font-size:.76rem;color:var(--text-muted);max-width:380px;margin:0 auto 12px;line-height:1.65;}
.pf-links{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:12px;}
.pf-link{display:inline-flex;align-items:center;gap:5px;padding:7px 13px;border-radius:24px;font-size:.76rem;font-weight:700;text-decoration:none;transition:transform .15s;}
.pf-link:hover{transform:translateY(-2px);}
.pf-link.ig{background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045);color:#fff;}
.pf-link.port{background:var(--brown-dark);color:var(--amber-light);}
.pf-copy{font-size:.65rem;color:var(--text-muted);border-top:1px solid var(--amber-light);padding-top:10px;margin-top:10px;}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:5px;height:5px;}::-webkit-scrollbar-track{background:transparent;}::-webkit-scrollbar-thumb{background:var(--brown-light);border-radius:3px;}::-webkit-scrollbar-thumb:hover{background:var(--brown);}
