/* =========================
   OBSERVATIONS — CLEAN UI
   ========================= */

.obs-page{
  display:flex;
  flex-direction:column;
  gap: 18px;
  font-family: "Montserrat", "Segoe UI", Arial, sans-serif;
}
body[data-theme="dark"] .obs-page{
  color: rgba(255,255,255,.92);
}
.obs-page :is(input, textarea, select, button){
  font-family: "Montserrat", "Segoe UI", Arial, sans-serif;
}
.obs-page :is(input, textarea)::placeholder{
  font-family: "Montserrat", "Segoe UI", Arial, sans-serif;
  font-style: normal;
  letter-spacing: .02em;
}

/* HERO */
.obs-hero{
  position: relative;
  overflow:hidden;
  padding: 22px;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(8,12,20,.7), rgba(8,12,20,.7)),
    url("/static/img/observation.png");
  background-size: cover;
  background-position: center;
}
.obs-hero__glow{
  position:absolute;
  inset:auto;
  width: 520px;
  height: 520px;
  border-radius: 50%;
  filter: blur(40px);
  opacity:.30;
  pointer-events:none;
}
.obs-hero__glow--a{ left:-140px; top:-220px; background: rgba(58,166,255,.55); }
.obs-hero__glow--b{ right:-160px; bottom:-260px; background: rgba(106,92,255,.55); }

.obs-hero__content{ position:relative; z-index:1; }
.obs-hero__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.obs-stats{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.stat{
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  border-radius: 14px;
  padding: 12px 14px;
}
.stat__k{ font-size:.82rem; color: rgba(255,255,255,.62); }
.stat__v{ font-size: 1.35rem; font-weight: 900; color: rgba(255,255,255,.92); }

/* COMPOSER */
.obs-compose{
  padding: 16px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(120% 140% at 0% 0%, rgba(58,166,255,.12), transparent 55%),
    rgba(255,255,255,.04);
  display: grid;
  gap: 14px;
  box-shadow: 0 18px 50px rgba(0,0,0,.35);
}

.obs-compose__head{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.obs-compose__head h2{
  margin: 6px 0 0;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: -0.01em;
}
.obs-compose__head .muted{
  margin-top: 6px;
  max-width: 60ch;
}

.obs-compose__head .btn{
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 900;
  border: 1px solid rgba(58,166,255,.45);
  background: linear-gradient(135deg, rgba(58,166,255,.35), rgba(106,92,255,.25));
  box-shadow: 0 10px 24px rgba(58,166,255,.25);
  color: rgba(255,255,255,.95);
}
.obs-compose__head .btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(58,166,255,.35);
}
.obs-compose__head .btn::after{
  content: " →";
}

/* Pro button tone (observations only) */
.obs-compose__head .btn{
  border-radius: 12px;
  font-weight: 700;
  letter-spacing: .02em;
  background: linear-gradient(180deg, rgba(16,26,44,.85), rgba(12,20,34,.92));
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
}
.obs-compose__head .btn:hover{
  transform: translateY(-1px);
  border-color: rgba(58,166,255,.4);
  box-shadow: 0 14px 28px rgba(0,0,0,.4);
}
.obs-compose__head .btn::after{
  content: "";
}

.obs-compose-toggle{
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.obs-compose-toggle__icon{
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform .2s ease;
}
.obs-compose-toggle__icon svg{
  width: 18px;
  height: 18px;
  display: block;
}
#obs-composer[aria-expanded="true"] .obs-compose-toggle__icon{
  transform: rotate(180deg);
}

.obs-compose-body{
  display: grid;
  gap: 12px;
  padding-top: 4px;
}

.obs-compose[aria-expanded="false"] .obs-compose-body{
  display: none;
}

.obs-form{
  display: grid;
  gap: 12px;
}

.obs-form-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
@media (max-width: 800px){
  .obs-form-grid{ grid-template-columns: 1fr; }
}

.form-field{
  display: grid;
  gap: 6px;
}

.form-field label{
  font-size: 12px;
  font-weight: 800;
  color: rgba(255,255,255,.78);
  text-transform: uppercase;
  letter-spacing: .06em;
}

.form-field .input{
  width: 100%;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.92);
  padding: 10px 12px;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.form-field .input:focus{
  border-color: rgba(58,166,255,.45);
  box-shadow: 0 0 0 4px rgba(58,166,255,.18);
  background: rgba(8,18,32,.55);
}

.form-field textarea.input{
  min-height: 90px;
  resize: vertical;
}

.form-field input[type="file"].input{
  padding: 10px 12px;
  border-style: dashed;
  cursor: pointer;
}

.form-field--consent label{
  text-transform: none;
  letter-spacing: normal;
}
.obs-consent{
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.88);
  font-size: 13px;
  line-height: 1.35;
  cursor: pointer;
}
.obs-consent:has(input:checked){
  border-color: rgba(25,193,180,.45);
  background: rgba(25,193,180,.12);
}
.obs-consent input{
  margin-top: 2px;
  accent-color: #0009EB;
}
.obs-consent-help{
  margin: 2px 2px 0;
  font-size: 12px;
  color: rgba(255,255,255,.62);
}

.file-drop{
  position: relative;
}
.file-drop__input{
  position: absolute;
  inset: 0;
  opacity: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}
.file-drop__label{
  display: grid;
  gap: 6px;
  place-items: center;
  padding: 18px;
  border-radius: 14px;
  border: 2px dashed rgba(255,255,255,.18);
  background: rgba(10,18,32,.45);
  color: rgba(255,255,255,.85);
  text-align: center;
  transition: border-color .15s ease, background .15s ease, transform .15s ease;
}
.file-drop__clear{
  margin-top: 6px;
  border: 0;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.92);
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  cursor: pointer;
}
.file-drop__clear:hover{
  background: rgba(255,255,255,.16);
}
.file-drop__label:hover{
  border-color: rgba(58,166,255,.55);
  background: rgba(12,24,40,.6);
  transform: translateY(-1px);
}
.file-drop__title{
  font-weight: 900;
}
.file-drop__sub{
  font-size: 12px;
  color: rgba(255,255,255,.6);
  letter-spacing: .02em;
}

.obs-icon-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
}
.obs-icon-option{
  display: grid;
  gap: 6px;
  align-items: center;
  justify-items: center;
  padding: 10px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  cursor: pointer;
  font-size: 12px;
  color: rgba(255,255,255,.8);
  text-align: center;
}
.obs-icon-option img{
  width: 28px;
  height: 28px;
  object-fit: contain;
}

body[data-theme="clair"] .obs-icon-option img{
  background: rgba(0,0,0,.12);
  border-radius: 999px;
  padding: 4px;
}
.obs-icon-option input{
  accent-color: #0009EB;
}
.obs-icon-option:has(input:checked){
  border-color: rgba(0,9,235,.45);
  box-shadow: 0 10px 22px rgba(0,9,235,.18);
}

.obs-form-actions{
  display: flex;
  justify-content: flex-end;
  padding-top: 4px;
}
.obs-form-actions--top{
  padding-top: 0;
  margin-bottom: 6px;
}

/* TOOLBAR */
.obs-form-actions .btn{
    border-radius: 12px;
    font-weight: 700;
    letter-spacing: .02em;
    border: 1px solid rgba(0,10,255,1);
    background: rgba(0,10,255,.45);
    color: #fff;
    box-shadow: 0 8px 20px rgba(0,10,255,.55);
    font-size: .74rem;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: 7px 12px;
    transition: transform .15s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
  }
  .obs-form-actions .btn:hover{
    transform: translateY(-1px);
    border-color: rgba(255,255,255,.35);
  }

.obs-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 14px;
  border-radius: 16px;
  flex-wrap: wrap;
}
.obs-last-updated{
  font-size: .8rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
}

/* LAYOUT */
.obs-layout{
  display: block;
  gap: 16px;
  align-items: start;
}
.obs-side{
  display: none;
}
.obs-main{
  display: grid;
  gap: 16px;
  padding-left: 0;
  max-width: 1220px;
  margin: 0 auto;
}
.obs-mini-map{
  padding: 0;
  border: none;
  margin-top: 0;
  background: transparent;
  transform: none;
}
.obs-mini-map--full{
  width: 100%;
  max-width: 1100px;
  display: grid;
  gap: 10px;
  align-items: center;
  margin: 0 auto;
}
.obs-mini-map__head h3{
  margin: 6px 0 0;
}
.obs-mini-map__body{
  margin-top: 8px;
  display: grid;
  place-items: center;
  padding: 0;
  border-radius: 12px;
  border: none;
  background: transparent;
  position: relative;
}
.obs-mini-map__body--plain{
  padding: 0;
  border: none;
  background: transparent;
}
.obs-mini-map__map{
  width: 100%;
  height: 360px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
  position: relative;
}

@media (max-width: 700px){
  .obs-mini-map__map{
    height: 300px;
  }
}
.obs-mini-map__map .leaflet-control-attribution{
  font-size: 9px;
  opacity: 0.35;
  background: transparent;
}
.obs-mini-map__map .leaflet-control-attribution a{
  color: rgba(255,255,255,.7);
}

.obs-mini-map__map::after{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 25% 20%, rgba(59,130,246,.2), transparent 55%),
    linear-gradient(180deg, rgba(1,4,12,.3), rgba(1,4,12,.7));
  mix-blend-mode: multiply;
}
.map-popup{
  font-size: 12px;
  color: #0b1220;
}
.map-popup__title{
  font-weight: 800;
  margin-bottom: 6px;
}
.map-popup__list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 4px;
}
.map-popup__link{
  color: #0b1220;
  text-decoration: none;
  font-weight: 700;
}
.map-popup__link:hover{
  text-decoration: underline;
}
.map-popup__more{
  margin-top: 6px;
  font-weight: 700;
  color: rgba(11,18,32,.65);
}
body[data-theme="dark"] .map-popup,
body[data-theme="dark"] .map-popup__link,
body[data-theme="dark"] .map-popup__more{
  color: rgba(255,255,255,.9);
}
.obs-mini-map__status{
  margin-top: 8px;
  font-size: 12px;
  color: rgba(255,255,255,.6);
  font-weight: 700;
  letter-spacing: .02em;
  text-align: right;
}
.obs-search{
  flex: 1;
  min-width: 220px;
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
}
.obs-search svg{
  width: 18px;
  height: 18px;
  opacity:.85;
}
#obsSearch{
    width: 100%;
    border: none;
    outline:none;
    background: transparent;
    color: #0f172a;
  }
  #obsSearch::placeholder{ color: rgba(15,23,42,.45); }
  body[data-theme="dark"] #obsSearch{
    color: #ffffff;
  }
  body[data-theme="dark"] #obsSearch::placeholder{
    color: rgba(255,255,255,.5);
  }

#obs_timestamp{
  color-scheme: light;
}
#obs_timestamp::-webkit-calendar-picker-indicator{
  opacity: 1;
  filter: invert(0);
  cursor: pointer;
}
body[data-theme="dark"] #obs_timestamp{
  color-scheme: dark;
}
body[data-theme="dark"] #obs_timestamp::-webkit-calendar-picker-indicator{
  filter: invert(1);
}

.obs-filters{
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
}
.filter-btn{
  border-radius: 999px;
  padding: 8px 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.82);
  cursor:pointer;
  font-weight: 700;
  font-size: .88rem;
}
.filter-btn.active{
  background: linear-gradient(135deg, rgba(58,166,255,.22), rgba(106,92,255,.18));
  border-color: rgba(58,166,255,.35);
}

/* GRID */
.obs-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  content-visibility: auto;
  contain-intrinsic-size: 900px;
}
.obs-grid-skeleton{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  content-visibility: auto;
  contain-intrinsic-size: 900px;
}
body:not(.obs-ready) .obs-grid{
  opacity: 0;
  pointer-events: none;
}
body.obs-ready .obs-grid-skeleton{
  display:none;
}
body:not(.obs-ready) .obs-grid-skeleton{
  animation: obsSkeletonPulse 1.2s linear infinite;
}
@keyframes obsSkeletonPulse{
  0%{ opacity: .8; }
  50%{ opacity: .5; }
  100%{ opacity: .8; }
}
.obs-pagination{
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  padding: 8px 0 0;
}
.obs-pagination.is-loading{
  opacity: .8;
  pointer-events: none;
}
.obs-load-sentinel{
  width: 100%;
  height: 1px;
}
.obs-grid-loader{
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: inherit;
  gap: 16px;
}
.obs-card--skeleton{
  min-height: 410px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  overflow: hidden;
}
.obs-skel-media{
  height: 250px;
  background: linear-gradient(90deg, rgba(255,255,255,.06) 20%, rgba(255,255,255,.13) 50%, rgba(255,255,255,.06) 80%);
  background-size: 240% 100%;
  animation: obsSkeleton 1.2s linear infinite;
}
.obs-skel-body{
  padding: 14px;
  display: grid;
  gap: 10px;
}
.obs-skel-line{
  height: 12px;
  border-radius: 10px;
  background: linear-gradient(90deg, rgba(255,255,255,.06) 20%, rgba(255,255,255,.13) 50%, rgba(255,255,255,.06) 80%);
  background-size: 240% 100%;
  animation: obsSkeleton 1.2s linear infinite;
}
.obs-skel-line--short{
  width: 70%;
}
@keyframes obsSkeleton{
  from { background-position: 100% 0; }
  to { background-position: -100% 0; }
}

.obs-rate-toast{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 3000;
  max-width: min(92vw, 360px);
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(248,113,113,.5);
  background: rgba(30,8,8,.92);
  color: #fff;
  font-size: .9rem;
  font-weight: 700;
  box-shadow: 0 14px 30px rgba(0,0,0,.35);
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
}
.obs-rate-toast.is-visible{
  opacity: 1;
  transform: translateY(0);
}
.obs-pagination .btn{
  border-radius: 12px;
  font-weight: 700;
  letter-spacing: .02em;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(14,20,32,.9), rgba(10,16,28,.96));
  color: rgba(255,255,255,.9);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
}
.obs-pagination .btn.btn--primary{
  border-color: rgba(25,193,180,.4);
  background: linear-gradient(180deg, rgba(25,193,180,.95), rgba(25,193,180,.7));
  color: rgba(8,18,28,.92);
}
@media (max-width: 1100px){
  .obs-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 700px){
  .obs-grid{ grid-template-columns: 1fr; }
}
@media (max-width: 700px){
  .obs-layout{ grid-template-columns: 1fr; }
  .obs-side{ position: relative; top: auto; }
}

/* CARD */
.obs-card{
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(140% 140% at 0% 0%, rgba(58,166,255,.08), transparent 55%),
    radial-gradient(140% 140% at 100% 0%, rgba(106,92,255,.08), transparent 55%),
    rgba(8,12,20,.6);
  box-shadow: 0 16px 50px rgba(0,0,0,.42);
  display:flex;
  flex-direction:column;
  min-height: 410px;
  transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
  position: relative;
}

.obs-card.obs-highlight{
  border-color: rgba(34,211,255,.55);
  box-shadow: 0 18px 60px rgba(34,211,255,.25);
  transform: translateY(-2px);
}

/* Accent line */
.obs-card::before{
  content: none;
}
.obs-card::after{
  content:"";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(180px 120px at 10% 0%, rgba(255,255,255,.08), transparent 65%),
    radial-gradient(180px 120px at 90% 0%, rgba(255,255,255,.06), transparent 65%);
  opacity: .35;
  pointer-events: none;
}
.obs-card.accent-orage::before{ background: rgba(255,77,109,.65); }
.obs-card.accent-vent::before{ background: rgba(58,166,255,.65); }
.obs-card.accent-pluie::before{ background: rgba(80,200,255,.65); }
.obs-card.accent-neige::before{ background: rgba(255,255,255,.65); }
.obs-card.accent-grele::before{ background: rgba(180,120,255,.65); }
.obs-card.accent-beau::before{ background: rgba(255,190,60,.75); }
.obs-card.accent-autre::before{ background: rgba(255,255,255,.12); }

/* MEDIA */
.obs-media{
  position:relative;
  height: 250px;
  background: rgba(4,8,16,.6);
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.obs-media img{
  width:100%;
  height:100%;
  object-fit: cover;
  object-position: center center;
  display:block;
  filter: saturate(1.05) contrast(1.05);
  border-radius: 0;
}
.obs-media__empty{
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
  text-align:center;
  padding: 12px;
  color: rgba(255,255,255,.8);
  background:
    radial-gradient(120% 120% at 50% 0%, rgba(58,166,255,.12), transparent 60%);
}
.empty-ico{ font-size: 1.5rem; }
.empty-title{ font-weight: 900; margin-top: 6px; }
.empty-sub{ font-size:.86rem; opacity:.75; }

.obs-overlay{
  position:absolute;
  inset: 0;
  padding: 12px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  background: linear-gradient(to bottom, rgba(0,0,0,.35), transparent 55%, rgba(0,0,0,.35));
}

/* Type badge */
.type-badge{
  width: fit-content;
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(12,22,42,.65);
  color: rgba(255,255,255,.92);
  font-weight: 900;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .3px;
}
.type-badge .dot{
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(58,166,255,.95);
  box-shadow: 0 0 0 6px rgba(58,166,255,.15);
}

/* meta pills */
.obs-meta-top{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 2px;
}
.obs-meta-top--plain{
  align-items: center;
  font-size: .9rem;
  font-weight: 500;
  color: rgba(255,255,255,.8);
}
.obs-meta-text{
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.obs-meta-icon{
  width: 14px;
  height: 14px;
  display: inline-block;
  filter: brightness(0) invert(1);
  opacity: .9;
}
.obs-meta-text--loc::after{
  content: "•";
  margin-left: 2px;
  color: rgba(255,255,255,.35);
}
.obs-media-consent-badge{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 9px;
  border-radius: 999px;
  border: 1px solid rgba(25,193,180,.45);
  background: rgba(25,193,180,.18);
  color: rgba(220,255,250,.95);
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .02em;
  line-height: 1;
}
.obs-media-consent-badge::before{
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #19c1b4;
  box-shadow: 0 0 0 4px rgba(25,193,180,.18);
}
.pill{
  display:inline-flex;
  align-items:center;
  gap: 7px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.35);
  color: rgba(255,255,255,.95);
  font-size: .82rem;
  font-weight: 900;
  max-width: 100%;
}
.pill svg{ width: 14px; height: 14px; opacity:.95; }
.pill--loc{
  background: linear-gradient(135deg, rgba(58,166,255,.35), rgba(106,92,255,.22));
  border-color: rgba(58,166,255,.45);
}
.pill--time{
  background: rgba(255,255,255,.14);
  color: rgba(255,255,255,.92);
  border-color: rgba(255,255,255,.28);
}

/* BODY */
.obs-body{
  padding: 14px 14px 10px;
  display:flex;
  flex-direction:column;
  gap: 12px;
}
.obs-value{
  margin:0;
  font-size: 1.08rem;
  font-weight: 800;
  color: rgba(255,255,255,.95);
  line-height: 1.3;
  margin-top: 8px;
  display:-webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:hidden;
}
.obs-author-name{
  font-weight: 900;
  color: rgba(255,255,255,.95);
}
.obs-title-sep{
  margin: 0 6px 0 4px;
  color: rgba(255,255,255,.7);
}
.obs-value-text{
  font-style: italic;
  font-weight: 500;
  color: rgba(255,255,255,.85);
}
.author-date{
  font-size:.85rem;
  color: rgba(255,255,255,.8);
  font-weight: 800;
}

/* ACTIONS */
.obs-actions-row{
  margin-top: auto;
  padding: 8px 10px 10px;
  border-top: 1px solid rgba(255,255,255,.08);
  display:flex;
  align-items:center;
  justify-content: flex-start;
  gap: 8px;
}

.icon-btn{
  display:inline-flex;
  align-items:center;
  gap: 0;
  padding: 6px;
  border-radius: 999px;
  border: 0;
  background: transparent;
  color: rgba(255,255,255,.88);
  cursor:pointer;
  font-weight: 900;
  transition: transform .16s ease, color .16s ease, filter .16s ease;
}
.icon-btn .ico{ font-size: .95rem; }
.icon-btn .ico svg{
  width: 16px;
  height: 16px;
  display: block;
}
.icon-btn .ico img{
  width: 20px;
  height: 20px;
  display: block;
  filter: brightness(0) invert(1);
  opacity: .9;
}
.icon-btn .count{ font-weight: 900; }


.icon-btn:hover{
  transform: translateY(-1px) scale(1.03);
}
.icon-btn:active{
  transform: translateY(0) scale(.98);
}

/* Icon-only actions */
.obs-actions-row .icon-btn{
  box-shadow: none;
  letter-spacing: 0;
}
.obs-actions-row .icon-btn .count{
  display: none;
}
.obs-actions-row .like-btn .count{
  display: inline-block;
  margin-left: 6px;
  font-weight: 800;
  font-size: .9rem;
  color: rgba(255,255,255,.9);
}
.obs-actions-row .open-drawer-btn .count{
  display: inline-block;
  margin-left: 6px;
  font-weight: 800;
  font-size: .9rem;
  color: rgba(255,255,255,.9);
}
.obs-actions-row .icon-btn:hover .ico img{
  opacity: 1;
}

/* Like/favorite filled color on active */
.obs-actions-row .like-btn.liked .ico img{
  filter: invert(42%) sepia(91%) saturate(1650%) hue-rotate(315deg) brightness(1.08) contrast(1.1);
  opacity: 1;
}
.obs-actions-row .favorite-btn.is-favorite .ico img{
  filter: invert(82%) sepia(54%) saturate(1320%) hue-rotate(4deg) brightness(1.05) contrast(1.08);
  opacity: 1;
}

.icon-btn:disabled,
.open-btn:disabled{
  opacity:.55;
  cursor:not-allowed;
}

.like-btn.liked{
  background: transparent;
  border: 0;
}

.favorite-btn.is-favorite{
  background: transparent;
  border: 0;
  color: rgba(255,255,255,.95);
}

.report-btn{
  margin-left: auto;
  background: transparent;
}
.report-btn .ico{
  font-size: 16px;
  font-weight: 900;
  color: rgba(248,113,113,.95);
}
.report-btn span:not(.ico){
  display: inline-block;
  font-weight: 800;
  font-size: .9rem;
  letter-spacing: .06em;
  color: rgba(255,255,255,.9);
  margin-left: 6px;
}

.open-btn{
  margin-left:auto;
  padding: 9px 12px;
  border-radius: 14px;
  border: 1px solid rgba(58,166,255,.30);
  background: radial-gradient(120% 120% at 0% 0%, rgba(58,166,255,.28), rgba(58,166,255,.10));
  color: rgba(255,255,255,.92);
  font-weight: 900;
  cursor:pointer;
}

/* EMPTY */
.obs-empty{
  padding: 22px;
  border-radius: 18px;
}

/* =========================
   DRAWER (MODAL)
   ========================= */

body.modal-open{ overflow: hidden; }

main.page{ z-index: auto; }

.comment-drawer{
  position: fixed;
  inset: 0;
  z-index: 10050;
  display:grid;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  font-family: "Montserrat", "Segoe UI", Arial, sans-serif;
  contain: layout paint;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: none;
}
.comment-drawer.open{
  place-items:center;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.comment-drawer-inner{
  width: min(980px, calc(100vw - 26px));
  height: min(600px, calc(100vh - 100px));
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(58,166,255,.14), transparent 55%),
    radial-gradient(120% 120% at 100% 0%, rgba(106,92,255,.12), transparent 55%),
    rgba(12,22,42,.92);
  box-shadow: 0 18px 70px rgba(0,0,0,.65);

  display:grid;
  grid-template-columns: 1.2fr .9fr;
  gap: 12px;
  padding: 12px;
  position:relative;
  contain: layout paint;
  opacity: 1;
  transition: none;
}
.comment-drawer.open .comment-drawer-inner{
}

@media (max-width: 900px){
  .comment-drawer-inner{
    grid-template-columns: 1fr;
    height: min(78vh, 720px);
  }
  .drawer-left{ display:none; }
}

.drawer-close{
  position: absolute;
  right: 18px;
  top: 18px;
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(12,22,42,.65);
  color: rgba(255,255,255,.92);
  cursor: pointer;
  display: grid;
  place-items: center;
  font-size: 22px;
  line-height: 0;
  z-index: 20;
}

.drawer-close:hover{
  background: rgba(255,255,255,.08);
}

/* LEFT */
.drawer-left{
  border-radius: 16px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.drawer-left img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
}

/* RIGHT */
.drawer-right{
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.drawer-head{
  padding: 14px 16px 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.drawer-meta{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items:center;
}
.drawer-author{
  padding-left: 4px;
  font-weight: 900;
  color: rgba(255,255,255,.92);
  font-size: .9rem;
  letter-spacing: .2px;
}
.drawer-author::before{
  content: "|";
  margin: 0 6px 0 2px;
  color: rgba(255,255,255,.45);
  font-weight: 700;
}
.drawer-pill{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(12,22,42,.55);
  color: rgba(255,255,255,.9);
  font-size: .82rem;
  font-weight: 800;
}
.drawer-pill[hidden]{
  display: none;
}
.drawer-pill--time{
  font-style: italic;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.88);
  border-color: rgba(255,255,255,.25);
}
.drawer-pill--loc{
  background: linear-gradient(135deg, rgba(58,166,255,.28), rgba(106,92,255,.18));
  border-color: rgba(58,166,255,.35);
}
.drawer-pill--consent{
  background: rgba(25,193,180,.18);
  border-color: rgba(25,193,180,.45);
  color: rgba(220,255,250,.95);
}
.drawer-pill--author{
  background: rgba(255,255,255,.06);
}

/* Scroll area */
.drawer-scroll{
  min-height:0;
  overflow:auto;
  padding: 12px 14px;
  flex: 1;
  scroll-behavior: smooth;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
}

.drawer-comments-list{
  min-height: 0;
  overflow: auto;
  padding: 10px 16px 12px;
  contain: content;
}

/* Comments */
.drawer-comment{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  border-radius: 14px;
  padding: 10px 12px;
  margin-bottom: 10px;
  max-width: 100%;
  overflow: hidden;
}
.drawer-comment-meta{
  display:flex;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 6px;
  font-size: .85rem;
}
.drawer-comment-meta .comment-delete-btn{
  margin-left: auto;
  border: 0;
  background: transparent;
  color: rgba(255,255,255,.55);
  cursor: pointer;
  padding: 2px;
  display: inline-flex;
  align-items: center;
}
.drawer-comment-meta .comment-delete-btn svg{
  width: 18px;
  height: 18px;
}
.drawer-comment-meta .comment-delete-btn:hover{
  color: rgba(239,68,68,.9);
}
.drawer-comment-author{ font-weight: 900; color: rgba(255,255,255,.92); }
.drawer-comment-time{ color: rgba(255,255,255,.55); }
.drawer-comment-body{
  color: rgba(255,255,255,.86);
  line-height: 1.35;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: pre-wrap;
}

/* Composer sticky */
.drawer-form{
  border-top: 1px solid rgba(255,255,255,.08);
  background: transparent;
  padding: 10px 12px;
  margin-top: auto;
}
.drawer-compose{
  display:grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items:center;
  max-width: 720px;
  margin: 0 auto;
}

.drawer-form .btn{
  height: 40px;
  padding: 0 14px;
  border-radius: 12px;
  border: 1px solid rgba(58,166,255,.35);
  background: rgba(24,90,170,.9);
  color: rgba(255,255,255,.95);
  font-weight: 900;
  cursor: pointer;
  white-space: nowrap;
  transition: border-color .15s ease, background .15s ease, filter .15s ease;
}

.drawer-form .btn:hover{
  border-color: rgba(58,166,255,.45);
  filter: brightness(1.05);
}

.drawer-form .btn:disabled{
  opacity: .55;
  cursor: not-allowed;
}

#drawerTime{
  justify-self: center;
  text-align: center;
  font-size: .85rem;
  opacity: .85;
}



#drawerTextarea{
  width: 100%;
  resize:none;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: transparent;
  color: rgba(255,255,255,.92);
  font-family: "Segoe UI", Arial, sans-serif;
  font-size: 0.95rem;
  padding: 10px 12px;
  outline:none;
  min-height: 40px;
  max-height: 120px;
  line-height: 1.35;
  text-align: left;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
  box-shadow: none;
}
#drawerTextarea:focus{
  border-color: rgba(255,255,255,.28);
  background: transparent;
  box-shadow: none;
}
#drawerTextarea::placeholder{
  color: rgba(255,255,255,.45);
  font-family: "Montserrat", "Segoe UI", Arial, sans-serif;
  font-style: normal;
  letter-spacing: 0;
}

.drawer-hint{
  margin: 8px 2px 0;
  font-size: .85rem;
}

/* =========================
   REPORT MODAL
   ========================= */

.report-modal{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
}

.report-modal.open{
  display: grid;
  place-items: center;
}

.report-modal__inner{
  width: min(520px, calc(100vw - 26px));
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(248,113,113,.12), transparent 55%),
    rgba(12,22,42,.92);
  box-shadow: 0 18px 70px rgba(0,0,0,.65);
  padding: 20px;
  position: relative;
}

.report-close{
  position: absolute;
  right: 16px;
  top: 16px;
  width: 36px;
  height: 36px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(12,22,42,.65);
  color: rgba(255,255,255,.92);
  cursor: pointer;
  display: grid;
  place-items: center;
  font-size: 20px;
}

.report-head h3{
  margin: 0 0 6px;
  font-size: 1.05rem;
}

body[data-theme="clair"] .report-head h3,
body[data-theme="clair"] .report-head .muted{
  color: #ffffff !important;
}

.report-form{
  display: grid;
  gap: 14px;
  margin-top: 12px;
}
.report-warning{
  border: 1px solid rgba(239,68,68,.45);
  background: rgba(239,68,68,.12);
  color: rgba(255,255,255,.92);
  padding: 10px 12px;
  border-radius: 12px;
  font-weight: 800;
  font-size: .85rem;
  display: flex;
  gap: 10px;
  align-items: center;
}
.report-warning__icon{
  width: 20px;
  height: 20px;
  flex: 0 0 auto;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.3));
}

.report-field{
  display: grid;
  gap: 6px;
}

.report-field span{
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255,255,255,.78);
}


.report-actions{
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}


body[data-theme="clair"] .report-modal__inner{
  background: #0f172a;
  border-color: rgba(15,23,42,.2);
}
body[data-theme="clair"] .report-warning{
  background: rgba(239,68,68,.18);
  border-color: rgba(239,68,68,.45);
}
body[data-theme="clair"] .report-field span{
  color: rgba(255,255,255,.82);
}

.report-feedback{
  margin: 4px 0 0;
  font-size: .85rem;
}
