/* ===========================================================
   Tasha Observes Birds — screen-level styles (all pages)
   Loads after journal.css
   =========================================================== */

/* screen switching */
.screen{display:none;}
.screen.active{display:block;animation:screenIn .28s var(--ease);}
@keyframes screenIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

/* back button */
.back-btn{display:inline-flex;align-items:center;gap:5px;font-family:var(--ui);font-weight:800;
  font-size:13px;color:var(--ink-soft);background:none;border:none;padding:18px 0 0;cursor:pointer;
  margin-bottom:-10px;}
.back-btn:hover{color:var(--moss-deep);}
.back-btn svg{transition:transform .15s;}
.back-btn:hover svg{transform:translateX(-3px);}

/* page header pattern */
.crumbs{display:flex;align-items:center;gap:9px;font-family:var(--ui);font-size:12.5px;
  font-weight:700;color:var(--ink-faint);padding:26px 0 4px;}
.crumbs .c-link{cursor:pointer;color:var(--ink-soft);}
.crumbs .c-link:hover{color:var(--moss-deep);}
/* when the back button is showing above, drop the crumbs' large top padding */
.back-btn:not([hidden]) ~ .screen .crumbs{padding-top:6px;}
.page-hero{padding:30px 0 26px;}
.page-hero .eyebrow{margin-bottom:10px;}
.page-hero h1[contenteditable]{outline:none;border-radius:8px;padding:2px 8px;margin-left:-8px;
  cursor:text;transition:background .15s;}
.page-hero h1[contenteditable]:hover{background:var(--moss-wash);}
.page-hero h1[contenteditable]:focus{background:var(--moss-wash);box-shadow:0 0 0 2px var(--moss);}
.page-hero h1[contenteditable]:empty::before{content:attr(data-ph);color:var(--ink-faint);}
.page-hero h1{font-family:var(--script);font-weight:700;font-size:44px;line-height:1.02;
  letter-spacing:-0.025em;color:var(--slate);margin:0;}
.page-hero p{font-family:var(--serif);font-size:17px;color:var(--ink-soft);
  margin:12px 0 0;max-width:60ch;line-height:1.55;}

/* generic surface card */
.surface{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);}

/* entry feed cards (home page) */
#entryFeed{display:flex;flex-direction:column;gap:16px;margin-top:24px;}
.entry-card{position:relative;display:flex;align-items:center;gap:18px;background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow-sm);overflow:hidden;cursor:pointer;transition:box-shadow .2s,transform .2s;}
.entry-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.ec-del{position:absolute;top:10px;right:10px;z-index:2;width:28px;height:28px;border-radius:8px;
  border:1px solid transparent;background:transparent;color:var(--ink-faint);cursor:pointer;
  display:grid;place-items:center;transition:color .12s,border-color .12s,background .12s;}
.ec-del:hover{border-color:#e74c3c;color:#c0392b;background:rgba(231,76,60,0.08);}
.ec-del svg{width:15px;height:15px;}
.ec-thumb{flex:0 0 140px;height:140px;overflow:hidden;background:var(--paper-2);
  margin:12px 0 12px 12px;border-radius:12px;}
.ec-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s;}
.entry-card:hover .ec-thumb img{transform:scale(1.05);}
.ec-body{flex:1;padding:18px 20px 18px 0;min-width:0;}
.entry-card:not(:has(.ec-thumb)) .ec-body{padding-left:20px;}
.ec-date{font-family:var(--ui);font-size:12px;font-weight:700;color:var(--ink-faint);margin-bottom:5px;}
.ec-title{font-family:var(--script);font-size:24px;font-weight:700;color:var(--slate);
  line-height:1.3;margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ec-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:9px;max-width:100%;}
/* keep chips (esp. location) from overflowing the card — truncate with ellipsis */
.ec-meta .chip{min-width:0;max-width:100%;}
.ec-meta .chip .cl{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;}
/* "…" details button — only shown when fields don't fit (mobile) */
.ec-more{display:none;align-items:center;gap:5px;margin-bottom:9px;
  font-family:var(--ui);font-weight:800;font-size:11px;letter-spacing:.02em;color:var(--ink-faint);
  background:transparent;border:1px solid var(--line);border-radius:20px;padding:3px 11px;cursor:pointer;}
.ec-more:hover{border-color:var(--moss);color:var(--moss-deep);}
.card-menu .cm-row{display:flex;gap:10px;padding:7px 10px;font-family:var(--ui);font-size:13px;}
.card-menu .cm-k{font-weight:800;color:var(--ink-faint);flex:0 0 64px;}
.card-menu .cm-v{font-weight:700;color:var(--ink);min-width:0;word-break:break-word;}
.ec-excerpt{font-family:var(--serif);font-size:14px;color:var(--ink-soft);line-height:1.55;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

/* toolbar (filters/search rows) */
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:0 0 22px;}
.field-input{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);
  border-radius:11px;padding:9px 13px;box-shadow:var(--shadow-sm);min-width:240px;}
.field-input svg{width:16px;height:16px;flex:0 0 16px;fill:none;stroke:var(--ink-faint);stroke-width:2;stroke-linecap:round;}
.field-input input{border:0;background:transparent;outline:none;font-family:var(--ui);font-weight:600;
  font-size:14.5px;color:var(--ink);width:100%;}
.field-input input::placeholder{color:var(--ink-faint);}
.pill{font-family:var(--ui);font-weight:800;font-size:12.5px;cursor:pointer;
  border:1px solid var(--line);background:#fff;color:var(--ink-soft);padding:8px 14px;
  border-radius:30px;display:inline-flex;gap:7px;align-items:center;transition:all .15s;}
.pill:hover{border-color:var(--moss);color:var(--moss-deep);}
.pill.on{background:var(--fir);color:var(--on-fir);border-color:var(--fir);}
.pill .n{font-size:11px;opacity:.7;}

/* ===================== ENTRY DETAIL ===================== */
.entry-layout{display:grid;grid-template-columns:1.5fr 1fr;gap:34px;align-items:start;}
.entry-gallery .photo.main{aspect-ratio:3/2;}
.entry-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:14px;}
.entry-thumbs .photo{aspect-ratio:1;}
.entry-side .eyebrow{margin-bottom:8px;}
.entry-h1{font-family:var(--script);font-weight:700;font-size:34px;line-height:1.05;
  letter-spacing:-0.02em;color:var(--slate);margin:4px 0 14px;}
.entry-h1-edit{outline:none;border-radius:6px;padding:2px 6px;margin-left:-6px;cursor:text;
  transition:background .15s;}
.entry-h1-edit:hover{background:var(--moss-wash);}
.entry-h1-edit:focus{background:var(--moss-wash);box-shadow:0 0 0 2px var(--moss);}
.entry-h1-edit:empty::before{content:attr(data-ph);color:var(--ink-faint);}
.entry-body{font-family:var(--serif);font-size:17px;line-height:1.68;color:var(--ink);margin-top:18px;}
.entry-body p{margin:0 0 14px;}
.section-label{font-family:var(--ui);font-size:11px;font-weight:800;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-faint);margin:24px 0 12px;}
.loc-card{padding:14px;}
.loc-card .loc-name{font-family:var(--ui);font-weight:800;font-size:15px;display:flex;align-items:center;gap:7px;}
.loc-card .mini-map{margin-top:10px;height:140px;border-radius:11px;overflow:hidden;position:relative;
  background:
    radial-gradient(circle at 60% 40%, rgba(90,122,79,0.16), transparent 60%),
    repeating-linear-gradient(0deg,transparent 0 26px,rgba(43,47,41,0.05) 26px 27px),
    repeating-linear-gradient(90deg,transparent 0 26px,rgba(43,47,41,0.05) 26px 27px),
    var(--sage-page);}
.mini-map .mm-pin{position:absolute;top:42%;left:58%;width:16px;height:16px;border-radius:50%;
  background:var(--moss);border:3px solid #fff;box-shadow:var(--shadow-sm);transform:translate(-50%,-50%);}
.entry-nav{display:flex;justify-content:space-between;gap:12px;margin-top:34px;
  border-top:1px solid var(--line);padding-top:22px;}
.entry-nav .en-btn{cursor:pointer;display:flex;flex-direction:column;gap:3px;text-decoration:none;max-width:46%;}
.entry-nav .en-dir{font-family:var(--ui);font-size:11px;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-faint);}
.entry-nav .en-title{font-family:var(--ui);font-weight:700;font-size:15px;color:var(--moss-deep);}
.entry-nav .en-btn.next{text-align:right;margin-left:auto;}

/* recordings */
.rec-list{display:flex;flex-direction:column;gap:10px;}

/* ===================== MAP ===================== */
.map-shell{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start;}
.map-canvas{height:560px;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);}
.bird-pin{filter:brightness(0.65) saturate(1.25) drop-shadow(0 1.5px 2px rgba(0,0,0,0.45));}
/* Leaflet chrome overrides */
.leaflet-control-zoom a{border-color:var(--line)!important;color:var(--ink)!important;font-family:var(--ui);}
.leaflet-control-zoom a:hover{background:var(--paper)!important;}
.leaflet-popup-content-wrapper{border-radius:12px;box-shadow:var(--shadow-md);}
.leaflet-popup-content{font-family:var(--ui);font-size:13px;font-weight:700;color:var(--ink);}
.map-pop-place{font-family:var(--ui);font-weight:800;font-size:13px;color:var(--ink);}
.map-pop-entries{display:flex;flex-direction:column;gap:5px;margin-top:7px;}
.map-pop-link{font-family:var(--ui);font-weight:700;font-size:12.5px;color:var(--moss-deep);
  text-decoration:none;cursor:pointer;display:inline-flex;align-items:center;gap:5px;}
.map-pop-link:hover{text-decoration:underline;}
.map-pop-link .arr{opacity:.65;}
.map-legend{background:rgba(255,255,255,0.92);border:1px solid var(--line);border-radius:11px;
  padding:9px 13px;font-family:var(--ui);font-size:11.5px;font-weight:700;color:var(--ink-soft);
  box-shadow:var(--shadow-sm);}

.loc-list .loc-row{display:flex;align-items:center;gap:12px;padding:13px 14px;cursor:pointer;
  border-radius:12px;transition:background .15s;}
.loc-list .loc-row:hover{background:var(--paper);}
.loc-list .loc-row.active{background:var(--moss-wash);}
.loc-row .dot{width:11px;height:11px;border-radius:50%;background:var(--moss);flex:0 0 11px;}
.loc-row .lr-main{flex:1;min-width:0;}
.loc-row .lr-name{font-family:var(--ui);font-weight:800;font-size:14.5px;color:var(--ink);}
.loc-row .lr-sub{font-family:var(--ui);font-size:12px;font-weight:700;color:var(--ink-faint);}
.loc-row .lr-count{font-family:var(--ui);font-weight:800;font-size:13px;color:var(--moss-deep);}

/* ===================== LIFELIST ===================== */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:26px;}
.stat{padding:20px 18px;text-align:center;}
.stat .num{font-family:var(--ui);font-weight:800;font-size:40px;line-height:1;color:var(--moss-deep);letter-spacing:-0.02em;}
.stat .lbl{font-family:var(--ui);font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-faint);margin-top:7px;}
.stat .progress{height:8px;border-radius:20px;background:var(--paper-2);overflow:hidden;margin-top:10px;}
.stat .progress > i{display:block;height:100%;background:var(--moss);border-radius:20px;}

.life-wrap{overflow:hidden;}
table.life{width:100%;border-collapse:collapse;}
table.life th{text-align:left;font-family:var(--ui);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:800;padding:14px 16px;border-bottom:1px solid var(--line);}
table.life td{padding:13px 16px;border-bottom:1px solid var(--line-soft);vertical-align:middle;font-family:var(--ui);
  font-size:14px;color:var(--ink-soft);}
table.life tr{transition:background .12s;}
table.life tbody tr:hover td{background:var(--paper);}
.ll-btn{display:inline-flex;align-items:center;gap:5px;font-family:var(--ui);font-weight:800;font-size:12px;
  padding:4px 10px;border-radius:8px;border:1.5px solid var(--line);background:#fff;color:var(--ink-soft);
  cursor:pointer;transition:all .12s;}
.ll-btn:hover{border-color:var(--moss);color:var(--moss-deep);}
.ll-btn.ll-edit{border-color:var(--moss);color:var(--moss-deep);background:var(--moss-wash);}
.ll-btn.ll-edit:hover{background:var(--moss);color:#fff;}
.ll-btn.ll-del{border-color:transparent;background:transparent;color:var(--ink-faint);padding:4px 6px;}
.ll-btn.ll-del:hover{border-color:#e74c3c;color:#c0392b;background:rgba(231,76,60,0.07);}
.ll-play{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--moss);background:var(--moss-wash);
  color:var(--moss-deep);cursor:pointer;display:inline-grid;place-items:center;padding:0;transition:all .12s;}
.ll-play:hover{background:var(--moss);color:#fff;}
.ll-play.playing{background:var(--moss);color:#fff;}
.ll-play-ic{width:13px;height:13px;fill:currentColor;}
.ll-nocall{color:var(--ink-faint);font-family:var(--ui);font-weight:700;}
table.life tr:last-child td{border-bottom:0;}
.ll-actions{display:flex;gap:6px;align-items:center;white-space:nowrap;}
/* shared fixed-position popover (used by the journal-card "…" field menu) */
.ll-menu{position:fixed;z-index:300;min-width:184px;background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:0 8px 28px rgba(0,0,0,0.16);padding:6px;display:none;flex-direction:column;gap:2px;}
.ll-menu:not([hidden]){display:flex;}
.sp-name{font-family:var(--ui);font-weight:800;font-size:15px;color:var(--ink);}
.sp-latin{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink-faint);}
.life-thumb{width:42px;height:42px;border-radius:9px;overflow:hidden;background:var(--paper-2);}
.life-thumb image-slot{display:block;width:100%;height:100%;}
.heard{font-family:var(--ui);font-size:12px;font-weight:700;color:var(--walnut-soft);font-style:normal;}

/* ===================== GALLERY ===================== */
.g-section{margin-bottom:36px;}
.g-month{font-family:var(--ui);font-weight:800;font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-faint);padding:0 0 14px;border-bottom:1px solid var(--line);margin-bottom:18px;}
/* natural-aspect masonry — images keep their shape, tags shown below */
.g-grid{columns:3;column-gap:16px;}
.gphoto{break-inside:avoid;margin:0 0 20px;cursor:pointer;display:block;}
.g-imgwrap{position:relative;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);}
.gphoto:hover .g-imgwrap{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.g-imgwrap img{width:100%;height:auto;display:block;}
.g-species{position:absolute;left:0;right:0;bottom:0;padding:20px 11px 9px;color:#fff;
  font-family:var(--ui);font-weight:800;font-size:13px;font-style:italic;
  background:linear-gradient(to top,rgba(0,0,0,0.62),transparent);
  text-shadow:0 1px 3px rgba(0,0,0,0.5);opacity:0;transition:opacity .2s;pointer-events:none;}
.gphoto:hover .g-species,.gphoto:focus-visible .g-species{opacity:1;}
.g-info{padding:9px 2px 0;text-align:center;}
.g-sp{font-family:var(--ui);font-weight:800;font-size:13.5px;color:var(--ink);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.g-cap{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink-soft);margin-top:2px;}
.g-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:7px;justify-content:center;}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;}
.lightbox.open{display:flex;}
.lb-backdrop{position:absolute;inset:0;background:rgba(10,10,8,0.88);}
.lb-frame{position:relative;z-index:1;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;}
.lb-img{max-width:88vw;max-height:78vh;object-fit:contain;border-radius:8px;box-shadow:0 16px 64px rgba(0,0,0,0.5);display:block;}
.lb-info{margin-top:14px;text-align:center;}
.lb-caption{font-family:var(--serif);font-size:15px;color:rgba(255,255,255,0.9);font-style:italic;}
.lb-meta{margin-top:5px;font-family:var(--ui);font-size:12.5px;font-weight:700;color:rgba(255,255,255,0.55);display:flex;gap:12px;justify-content:center;}
.lb-species{color:rgba(255,255,255,0.75);}
.lb-close{position:fixed;top:20px;right:22px;z-index:2;background:rgba(255,255,255,0.12);border:none;
  color:#fff;font-size:20px;width:38px;height:38px;border-radius:50%;cursor:pointer;display:grid;place-items:center;
  transition:background .15s;}
.lb-close:hover{background:rgba(255,255,255,0.22);}
.lb-nav{position:fixed;top:50%;transform:translateY(-50%);z-index:2;background:rgba(255,255,255,0.1);
  border:none;color:#fff;font-size:48px;line-height:1;padding:0 18px;height:72px;border-radius:8px;cursor:pointer;
  transition:background .15s,opacity .15s;}
.lb-nav:hover{background:rgba(255,255,255,0.2);}
.lb-prev{left:16px;}
.lb-next{right:16px;}

/* ===================== ABOUT ===================== */
.about-grid{display:grid;grid-template-columns:320px 1fr;gap:46px;align-items:start;}
.about-portrait{width:100%;aspect-ratio:4/5;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-md);
  background:linear-gradient(160deg,var(--paper-2),#d4cfbd);}
.about-portrait image-slot{display:block;width:100%;height:100%;}
/* not a .surface card — flat, page-tinted so it blends, with the brand mark as the pop */
.ig-card{display:flex;align-items:center;gap:13px;padding:12px 14px;margin-top:16px;text-decoration:none;
  background:var(--moss-wash);border:1px solid rgba(90,122,79,0.16);border-radius:14px;
  transition:background .15s,border-color .15s;}
.ig-card:hover{background:rgba(90,122,79,0.14);border-color:rgba(90,122,79,0.3);}
.ig-card .ig-mark{width:42px;height:42px;flex:0 0 42px;border-radius:12px;display:grid;place-items:center;
  background:rgba(90,122,79,0.16);}
.ig-card .ig-mark svg{width:24px;height:24px;fill:none;stroke:var(--moss-deep);stroke-width:2;color:var(--moss-deep);}
.ig-card>div{flex:1 1 auto;min-width:0;}
.ig-card .btn{flex:0 0 auto;}
.ig-card .ig-h{font-family:var(--ui);font-weight:800;font-size:13px;color:var(--ink);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ig-card .ig-sub{font-family:var(--ui);font-size:12.5px;font-weight:700;color:var(--ink-faint);}
.about-body{font-family:var(--serif);font-size:18px;line-height:1.7;color:var(--ink);}
.about-body .lead{font-size:22px;line-height:1.5;color:var(--slate);font-weight:500;margin:0 0 18px;}
.about-body p{margin:0 0 16px;}
.info-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:26px;}
.info-card{padding:20px;}
.info-card .ic-head{display:flex;align-items:center;gap:11px;margin:0 0 14px;}
.info-card .ic-head .ig-mark{width:36px;height:36px;flex:0 0 36px;border-radius:11px;display:grid;place-items:center;
  background:rgba(90,122,79,0.16);}
.info-card .ic-head .ig-mark svg{width:20px;height:20px;fill:none;stroke:var(--moss-deep);stroke-width:2;color:var(--moss-deep);}
.info-card h3{font-family:var(--ui);font-weight:800;font-size:16px;margin:0;color:var(--slate);}
.info-card ul{margin:0;padding:0;list-style:none;font-family:var(--ui);font-size:14px;font-weight:600;color:var(--ink-soft);}
.info-card li{padding:6px 0;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;gap:10px;}
.info-card li:first-child{border-top:0;}
.info-card li b{color:var(--ink);font-weight:800;}

/* ===================== ADMIN ===================== */
.admin-card{max-width:440px;padding:26px 28px;margin:6px 0 40px;}
.admin-login .field{margin-bottom:18px;}
.admin-error{color:#c0392b;font-family:var(--ui);font-weight:700;font-size:13px;margin:0 0 14px;}
.admin-msg{font-family:var(--serif);font-size:16px;line-height:1.55;color:var(--ink-soft);margin:0 0 20px;}
.admin-actions{display:flex;gap:12px;flex-wrap:wrap;}

/* ===================== COMPOSER ===================== */
.composer-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:34px;align-items:start;}
.composer-meta{margin-top:28px;padding-top:22px;border-top:1.5px solid var(--line);}
.composer-meta-row{display:flex;gap:14px;flex-wrap:wrap;}
.composer-meta-row .field{flex:1;min-width:120px;}
.cmeta-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 20px;}
.cmeta-grid .field{margin-bottom:16px;}

/* pill-style tag input */
.tag-pill-input{display:flex;flex-wrap:wrap;gap:8px;align-items:center;background:#fff;
  border:1px solid var(--line);border-radius:11px;padding:9px 11px;box-shadow:var(--shadow-sm);}
.tag-pill-input input{border:0;outline:none;background:transparent;font-family:var(--ui);
  font-weight:600;font-size:14px;flex:1;min-width:90px;color:var(--ink);}
.tag-pill-input input::placeholder{color:var(--ink-faint);}
.tpill{display:inline-flex;align-items:center;gap:5px;font-family:var(--ui);font-weight:800;
  font-size:12.5px;color:var(--fir-deep);background:var(--moss-wash);border-radius:20px;
  padding:4px 8px 4px 11px;}
.tpill-x{border:0;background:transparent;cursor:pointer;font-size:12px;color:var(--fir-deep);
  opacity:.55;padding:0;line-height:1;display:inline-flex;align-items:center;}
.tpill-x:hover{opacity:1;}

.field{margin-bottom:20px;}
.field > label{display:block;font-family:var(--ui);font-weight:800;font-size:13.5px;color:var(--slate);margin-bottom:8px;}
.req{color:#c0392b;margin-left:2px;}
.input-error{border-color:#c0392b!important;box-shadow:0 0 0 2px rgba(192,57,43,0.18)!important;}
.field .hint{font-family:var(--ui);font-size:12px;color:var(--ink-faint);font-weight:700;margin-top:7px;}
.input{width:100%;font-family:var(--ui);font-weight:600;font-size:15px;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px 14px;box-shadow:var(--shadow-sm);outline:none;}
.input::placeholder{color:var(--ink-faint);}
.input:focus{border-color:var(--moss);}
textarea.input{min-height:140px;resize:vertical;line-height:1.55;}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.dropzone{border:1.5px dashed var(--line);border-radius:16px;min-height:170px;display:grid;place-items:center;
  text-align:center;background:rgba(255,255,255,0.5);cursor:pointer;padding:22px;transition:border-color .15s,background .15s;}
.dropzone:hover{border-color:var(--moss);background:var(--moss-wash);}
.dropzone .dz-title{font-family:var(--ui);font-weight:800;font-size:17px;color:var(--slate);}
.dropzone .dz-sub{font-family:var(--ui);font-size:12.5px;font-weight:700;color:var(--ink-faint);margin-top:5px;}
.photo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:14px;}
.photo-grid image-slot{aspect-ratio:1;border-radius:11px;overflow:hidden;width:100%;}
.audio-drop{display:flex;align-items:center;gap:13px;border:1.5px dashed var(--line);border-radius:14px;
  background:rgba(255,255,255,0.5);padding:14px 16px;cursor:pointer;transition:border-color .15s,background .15s;}
.audio-drop:hover{border-color:var(--moss);background:var(--moss-wash);}
.audio-drop .mic{width:40px;height:40px;flex:0 0 40px;border-radius:50%;background:var(--moss);display:grid;place-items:center;}
.audio-drop .mic svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.audio-drop .ad-title{font-family:var(--ui);font-weight:800;font-size:14.5px;color:var(--slate);}
.audio-drop .ad-sub{font-family:var(--ui);font-size:12px;font-weight:700;color:var(--ink-faint);}
.tag-input{display:flex;flex-wrap:wrap;gap:8px;align-items:center;background:#fff;border:1px solid var(--line);
  border-radius:11px;padding:9px 11px;box-shadow:var(--shadow-sm);}
.tag-input .tagchip{font-family:var(--ui);font-weight:800;font-size:12.5px;color:var(--moss-deep);
  background:var(--moss-wash);border-radius:20px;padding:4px 10px;display:inline-flex;gap:5px;align-items:center;}
.tag-input .tagchip b{cursor:pointer;opacity:.6;}
.tag-input input{border:0;outline:none;background:transparent;font-family:var(--ui);font-weight:600;font-size:14px;flex:1;min-width:90px;}
.loc-autocomplete{position:relative;}
.loc-suggestions{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;
  border:1px solid var(--line);border-radius:11px;box-shadow:0 6px 24px rgba(0,0,0,0.10);
  z-index:200;overflow:hidden;max-height:230px;overflow-y:auto;}
.loc-suggestion{padding:10px 14px;font-family:var(--ui);font-size:13.5px;font-weight:600;
  color:var(--ink);cursor:pointer;border-bottom:1px solid var(--line);}
.loc-suggestion:last-child{border-bottom:0;}
.loc-suggestion:hover,.loc-suggestion.ls-active{background:var(--moss-wash);color:var(--fir-deep);}
.loc-suggestion .ls-sub{font-size:11.5px;color:var(--ink-faint);margin-top:2px;}

.composer-actions{display:flex;gap:11px;margin-top:10px;}
.composer-danger{margin-top:36px;padding-top:22px;border-top:1px solid var(--line);}
.map-pick{height:150px;border-radius:12px;margin-top:10px;position:relative;cursor:pointer;overflow:hidden;
  background:
    radial-gradient(circle at 55% 45%, rgba(90,122,79,0.18), transparent 55%),
    repeating-linear-gradient(0deg,transparent 0 24px,rgba(43,47,41,0.05) 24px 25px),
    repeating-linear-gradient(90deg,transparent 0 24px,rgba(43,47,41,0.05) 24px 25px),
    var(--sage-page);border:1px solid var(--line);}
.map-pick .mp-hint{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-family:var(--ui);
  font-weight:800;font-size:13px;color:var(--ink-soft);background:rgba(255,255,255,0.9);padding:6px 13px;border-radius:20px;box-shadow:var(--shadow-sm);}

/* locked guest state */
.locked{max-width:480px;margin:40px auto;text-align:center;padding:46px 38px;}
.locked .glyph-big{width:60px;height:60px;margin:0 auto 18px;background:var(--moss-deep);
  -webkit-mask:url(/img/favicon.png) center/contain no-repeat;mask:url(/img/favicon.png) center/contain no-repeat;}
.locked h2{font-family:var(--ui);font-weight:800;font-size:28px;margin:0 0 10px;color:var(--slate);letter-spacing:-0.02em;}
.locked p{font-family:var(--serif);font-size:16px;color:var(--ink-soft);margin:0 0 26px;line-height:1.55;}
.locked .gbtn{max-width:300px;margin:0 auto;}
.locked .back{display:inline-block;margin-top:20px;font-family:var(--ui);font-weight:800;font-size:13.5px;
  color:var(--ink-soft);cursor:pointer;}
.locked .back:hover{color:var(--moss-deep);}

/* touch-friendly active state for log items */
.log-item:active{padding-left:6px;background:var(--paper);}
/* make loc rows feel tappable */
.loc-list .loc-row:active{background:var(--moss-wash);}

/* ===================== RESPONSIVE ===================== */
@media(max-width:880px){
  .entry-layout,.map-shell,.about-grid,.composer-grid{grid-template-columns:1fr;}
  .composer-meta-row{flex-direction:column;gap:0;}
  .cmeta-grid{grid-template-columns:1fr;}
  .field.loc-autocomplete{max-width:100%!important;}
  .map-canvas{height:380px;}
  .stats{grid-template-columns:repeat(3,1fr);gap:10px;}
  .masonry{columns:2;}
  .g-grid{columns:2;}
  .info-cards{grid-template-columns:1fr;}
  .page-hero h1{font-size:34px;}
  /* toolbar: scrolls horizontally on small screens */
  .toolbar{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;
    padding-bottom:4px;scrollbar-width:none;}
  .toolbar::-webkit-scrollbar{display:none;}
  .field-input{min-width:180px;}
}
@media(max-width:560px){
  /* keep the three life-list tiles on one line, just narrower */
  .stats{grid-template-columns:repeat(3,1fr);gap:8px;}
  .stat{padding:14px 8px;}
  .stat .num{font-size:26px;}
  .stat .lbl{font-size:9px;letter-spacing:.06em;}
  .masonry{columns:2;}
  /* gallery → tight photo wall: bigger images packed across the width,
     species label overlaid on the image, no per-photo text block below */
  .g-section{margin-bottom:26px;}
  .g-month{padding-bottom:10px;margin-bottom:12px;}
  .g-grid{columns:2;column-gap:8px;}
  .gphoto{margin-bottom:8px;}
  .g-imgwrap{border-radius:10px;}
  .g-info{display:none;}
  .g-species{opacity:1;padding:16px 9px 7px;font-size:12px;}
  .ec-thumb{flex:0 0 90px;height:90px;}
  .ec-title{font-size:18px;}
  .ec-excerpt{display:none;}
  /* move the cramped chips into the "…" details menu */
  .ec-meta{display:none;}
  .ec-more{display:inline-flex;}
  .lb-nav{font-size:34px;padding:0 12px;height:56px;}
  .entry-thumbs,.photo-grid{grid-template-columns:repeat(2,1fr);}
  /* stack multi-image entry rows vertically on narrow screens */
  .entry-photo-row{flex-direction:column;}
  /* compact life list: name · species · photo · date — tap the row to open the entry */
  table.life{min-width:0;}
  .life .col-audio,.life .col-loc{display:none;}
  .life .ll-actions{display:none;}
  .life tbody tr{cursor:pointer;}
  table.life th,table.life td{padding:11px 8px;}
  .sp-name{font-size:14px;}
  /* composer stacks better */
  .row-2{grid-template-columns:1fr;}
  /* bigger touch targets for pills */
  .pill{padding:10px 16px;}
  /* about portrait stays a reasonable size */
  .about-portrait{aspect-ratio:3/4;}
  .about-grid{gap:28px;}
  /* entry nav takes full width */
  .entry-nav{flex-direction:column;gap:0;}
  .entry-nav .en-btn{max-width:100%;padding:14px 0;border-top:1px solid var(--line-soft);}
  .entry-nav .en-btn.prev{border-top:none;}
}

/* ===================== BLOCK EDITOR (composer) ===================== */
#blockEditor{display:flex;flex-direction:column;gap:4px;}

/* every block */
.eb{
  position:relative;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  overflow:hidden;transition:box-shadow .15s;
}
.eb:focus-within{box-shadow:0 0 0 2px var(--moss);}
.eb.eb-tip{border-left:3px solid var(--moss);}

/* hover controls — ↑ ↓ ✕ — top-right corner */
.eb-ctrl{
  position:absolute;top:8px;right:8px;
  display:flex;gap:2px;
  opacity:0;pointer-events:none;transition:opacity .15s;z-index:4;
}
.eb:hover .eb-ctrl,.eb:focus-within .eb-ctrl{opacity:1;pointer-events:auto;}
.eb-ctrl button{
  border:0;cursor:pointer;border-radius:6px;padding:3px 7px;
  font-family:var(--ui);font-weight:800;font-size:12px;line-height:1;
  background:rgba(255,255,255,.9);color:var(--ink-soft);
  box-shadow:0 1px 3px rgba(0,0,0,.1);transition:background .12s,color .12s;
}
.eb-ctrl button:hover{background:#fff;color:var(--ink);}
.eb-ctrl button.del:hover{background:#fee;color:#c33;}

/* text & tip content-editable */
.eb-text{
  min-height:88px;padding:14px 46px 26px 16px;outline:none;
  font-family:var(--serif);font-size:17px;line-height:1.7;color:var(--ink);
}
.eb-count{position:absolute;right:12px;bottom:7px;font-family:var(--ui);font-size:11px;font-weight:700;
  color:var(--ink-faint);opacity:0;transition:opacity .15s;pointer-events:none;}
.eb:focus-within .eb-count{opacity:1;}
.eb-count.over{color:#c0392b;}
.eb-tip .eb-text{
  font-style:italic;color:var(--ink-soft);
  background:var(--sage-page);
}
.eb-text:empty::before{content:attr(data-ph);color:var(--ink-faint);pointer-events:none;}
.eb-tip .eb-text:empty::before{font-style:italic;}

/* image block */
.eb-img-drop{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;padding:32px 20px;cursor:pointer;text-align:center;
  border:1.5px dashed var(--line);border-radius:13px;margin:10px;
  background:rgba(255,255,255,.5);transition:border-color .15s,background .15s;
}
.eb-img-drop:hover{border-color:var(--moss);background:var(--moss-wash);}
.eb-img-drop svg{width:28px;height:28px;stroke:var(--ink-faint);stroke-width:1.5;fill:none;stroke-linecap:round;}
.eb-img-drop span{font-family:var(--ui);font-weight:800;font-size:14px;color:var(--slate);}
.eb-img-drop small{font-family:var(--ui);font-size:12px;font-weight:700;color:var(--ink-faint);}

.eb-img-preview{position:relative;background:var(--paper-2);text-align:center;}
.eb-img-preview img{display:inline-block;max-width:100%;width:auto;height:auto;max-height:480px;vertical-align:middle;}
.eb-img-swap{
  position:absolute;bottom:10px;left:10px;
  background:rgba(0,0,0,.55);border:0;border-radius:20px;cursor:pointer;
  color:#fff;font-family:var(--ui);font-weight:800;font-size:12px;
  padding:5px 12px;
}
.eb-caption{
  width:100%;border:0;border-top:1px solid var(--line-soft);outline:none;
  font-family:var(--ui);font-size:13px;font-weight:600;color:var(--ink-soft);
  background:transparent;padding:9px 46px 9px 14px;
}
.eb-caption::placeholder{color:var(--ink-faint);}

/* audio block */
.eb-aud-drop{
  display:flex;align-items:center;gap:14px;
  padding:16px 48px 16px 16px;cursor:pointer;
  border:1.5px dashed var(--line);border-radius:13px;margin:10px;
  background:rgba(255,255,255,.5);transition:border-color .15s,background .15s;
}
.eb-aud-drop:hover{border-color:var(--moss);background:var(--moss-wash);}
.eb-aud-drop .mic{width:38px;height:38px;flex:0 0 38px;border-radius:50%;background:var(--moss);display:grid;place-items:center;}
.eb-aud-drop .mic svg{width:17px;height:17px;stroke:#fff;stroke-width:2;fill:none;stroke-linecap:round;}
.eb-aud-drop .lbl{font-family:var(--ui);font-weight:800;font-size:14px;color:var(--slate);}
.eb-aud-drop .sub{font-family:var(--ui);font-size:12px;font-weight:700;color:var(--ink-faint);}

.eb-aud-player{
  display:flex;align-items:center;gap:10px;
  padding:12px 48px 12px 14px;
}
.eb-aud-player audio{flex:1;height:34px;}

/* add-block row — always visible below the last block */
.eb-add-row{
  display:flex;align-items:center;gap:8px;
  padding:14px 0 2px;flex-wrap:wrap;
}
.eb-add-row::before{
  content:"+ Add block";
  font-family:var(--ui);font-size:11px;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-faint);margin-right:4px;
}
.eb-add-btn{
  display:inline-flex;align-items:center;gap:5px;
  border:1px solid var(--line);border-radius:20px;background:#fff;
  padding:6px 14px;font-family:var(--ui);font-weight:800;font-size:12.5px;
  color:var(--ink-soft);cursor:pointer;transition:all .15s;white-space:nowrap;
}
.eb-add-btn:hover{border-color:var(--moss);color:var(--moss-deep);background:var(--moss-wash);}
.eb-add-btn svg{width:13px;height:13px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}

/* ===================== ENTRY CONTENT BLOCKS (view) ===================== */
.entry-content{display:flex;flex-direction:column;gap:2px;}

.entry-block-paragraph{
  font-family:var(--serif);font-size:17px;line-height:1.68;color:var(--ink);
  margin:8px 0;
}
.entry-block-paragraph p{margin:0 0 12px;}
.entry-block-paragraph p:last-child{margin-bottom:0;}

.entry-block-tip{
  font-family:var(--serif);font-size:16px;line-height:1.65;
  font-style:italic;color:var(--ink-soft);
  background:var(--sage-page);border-left:3px solid var(--moss);
  border-radius:0 10px 10px 0;padding:14px 18px;margin:10px 0;
}

.entry-block-image{margin:16px 0;text-align:center;}
.entry-figure{display:inline-block;max-width:100%;margin:0;}
.entry-block-image img{
  display:block;max-width:100%;width:auto;height:auto;border-radius:14px;
  box-shadow:var(--shadow-sm);
}
.entry-block-image .img-caption{
  font-family:var(--ui);font-size:13px;font-weight:600;color:var(--ink);
  text-align:center;margin-top:8px;font-style:italic;
}
.entry-block-image .img-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;justify-content:center;}

/* justified photo rows (consecutive images, ≤3 per row, aspect-ratio preserved) */
.entry-photos{margin:16px 0;display:flex;flex-direction:column;gap:10px;}
.entry-photo-row{display:flex;gap:10px;align-items:flex-start;}
.entry-photo{flex:1 1 0;min-width:0;margin:0;}
.entry-photo img{display:block;width:100%;height:auto;border-radius:12px;box-shadow:var(--shadow-sm);}
.entry-photo-cap{font-family:var(--ui);font-size:12.5px;font-weight:600;font-style:italic;
  color:var(--ink-soft);text-align:center;margin-top:6px;}
.entry-photo-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px;justify-content:center;}

.entry-block-audio{margin:10px 0;}

/* ===================== ENTRY FULL-WIDTH LAYOUT ===================== */
.entry-full{max-width:740px;}
.entry-full .entry-h1{font-size:40px;}
.entry-edit-btn{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--ui);font-weight:800;font-size:13px;
  color:var(--ink-soft);cursor:pointer;border:1px solid var(--line);
  background:#fff;border-radius:20px;padding:6px 14px;
  transition:all .15s;
}
.entry-edit-btn:hover{border-color:var(--moss);color:var(--moss-deep);}
.entry-foot{margin-top:30px;padding-top:22px;border-top:1px solid var(--line);}

/* save confirmation toast */
.toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(20px);
  z-index:90;background:var(--fir);color:var(--on-fir);font-family:var(--ui);font-weight:700;font-size:14px;
  padding:13px 20px;border-radius:13px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:11px;
  opacity:0;pointer-events:none;transition:opacity .25s var(--ease),transform .25s var(--ease);max-width:90vw;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto;}
.toast .t-check{width:22px;height:22px;flex:0 0 22px;border-radius:50%;background:var(--moss);display:grid;place-items:center;
  color:#fff;font-size:13px;}
.toast a{color:var(--on-fir);text-decoration:underline;cursor:pointer;font-weight:800;}

/* freshly-added lifelist row highlight */
@keyframes rowGlow{from{background:var(--moss-wash);}to{background:transparent;}}
tr.just-added td{animation:rowGlow 2.6s var(--ease);}
.life-badge{font-family:var(--ui);font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  color:var(--moss-deep);background:var(--moss-wash);border:1px solid rgba(90,122,79,0.4);border-radius:20px;
  padding:2px 8px;margin-left:8px;vertical-align:middle;}
