/* 2025-10-02 07:03 Europe/Paris — v1.0.0 */
/* template/default/custom/modern.css */

/* ===== Design tokens ===== */
:root{
  --modern-font: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --modern-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  --modern-bg: #0b0c10;
  --modern-surface: #111318;
  --modern-elev: #171a21;
  --modern-text: #edf1f7;
  --modern-muted: #9aa4b2;
  --modern-brand: #5b8cff; /* accent */
  --modern-brand-2:#8e5bff;
  --modern-ok: #35c46e;
  --modern-warn:#ffcc66;
  --modern-err: #ff6b6b;
  --modern-radius: 14px;
  --modern-radius-sm:10px;
  --modern-gap: 14px;
  --modern-shadow: 0 8px 30px rgba(0,0,0,.35), 0 2px 8px rgba(0,0,0,.25);
  --focus-visible-color: var(--modern-brand);
  --text-size: 16px;
}

/* Auto dark via system */
@media (prefers-color-scheme: light){
  :root{
    --modern-bg:#f6f7fb; --modern-surface:#ffffff; --modern-elev:#ffffff;
    --modern-text:#0e1116; --modern-muted:#5b6676; --modern-shadow: 0 8px 26px rgba(33,35,41,.08), 0 2px 8px rgba(33,35,41,.06);
  }
}

/* ===== Global reset/typography overrides (non-destructive) ===== */
body{
  background: var(--modern-bg);
  color: var(--modern-text);
  font-family: var(--modern-font);
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
}
a{ color: var(--modern-text); border: none; text-decoration: none; }
a:hover{ opacity:.88; }
.emoji{ font-style: normal; }

/* Selection */
::selection{ background: var(--modern-brand); color:#fff; }

/* ===== Header/App Bar ===== */
#header_top{
  height: 60px; padding: 0 16px; margin: 0 0 18px;
  background: linear-gradient(135deg, var(--modern-brand), var(--modern-brand-2));
  border: none; box-shadow: var(--modern-shadow); border-radius: 0 0 18px 18px;
}
header h1 a{ color:#fff !important; font-weight:700; letter-spacing:.2px; }

/* User avatar/menu */
#user_links img{ width: 40px; height:40px; border:2px solid rgba(255,255,255,.35); }

/* Mobile menu button */
#menu_link.show{ display:block; font-size: 260%; color:#fff; }

/* Drop menu */
#menu nav{
  background: var(--modern-elev); border-radius: 16px;
  box-shadow: var(--modern-shadow); overflow: hidden;
}
#menu li a{
  color: var(--modern-text); border: none; height: 52px;
}
#menu a::before{ color: var(--modern-muted); }

/* ===== Containers / cards ===== */
main{ padding: 12px 0 40px; }
#content{ padding: 0 14px; }
.card{
  background: var(--modern-surface); border-radius: var(--modern-radius);
  box-shadow: var(--modern-shadow); border:1px solid rgba(255,255,255,.06);
}

/* System messages */
*[class^="message_"]{
  color: var(--modern-text);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border-left: 4px solid var(--modern-brand);
  padding:12px 14px; border-radius: 10px;
}
*[class="message_success"]{ border-left-color: var(--modern-ok); }
*[class="message_error"]{ border-left-color: var(--modern-err); }
*[class="message_info"]{ border-left-color: var(--modern-warn); }

/* ===== Buttons & inputs ===== */
.button{
  background: linear-gradient(135deg, var(--modern-brand), var(--modern-brand-2));
  color:#fff; border:none; border-radius: 12px; padding:10px 14px;
  box-shadow: var(--modern-shadow); transition: transform .08s ease, box-shadow .2s ease;
}
.button:hover{ transform: translateY(-1px); }
.button:active{ transform: translateY(0); }
.button[disabled]{ opacity:.5; filter: grayscale(1); }

input[type="text"],input[type="email"],input[type="password"],input[type="url"],input[type="number"],textarea,select{
  background: var(--modern-elev); color: var(--modern-text);
  border:1px solid rgba(255,255,255,.08); border-radius: 12px; padding:10px 12px;
}
input:focus,textarea:focus,select:focus{ outline:2px solid var(--modern-brand); outline-offset:1px; }

/* Password eye */
.password_container .password_view a{ background: linear-gradient(135deg, var(--modern-brand), var(--modern-brand-2)); }

/* ===== Breadcrumb & tools ===== */
#breadcrumb_tools nav, #breadcrumb, .breadcrumb_filter, #tools{
  color: var(--modern-text);
}
#tools a{
  background: var(--modern-elev); border-radius: 12px; width:42px; height:42px;
  box-shadow: var(--modern-shadow);
}
#tools a:hover{ color: var(--modern-brand); }

/* ===== Responsive grids (albums & photos) ===== */

/* Categories (albums) grid */
#thumbs_cat{
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(220px,1fr));
  gap: var(--modern-gap);
  margin: 6px 0 !important;
}
#thumbs_cat dl{
  width: 100% !important; max-width: none !important;
  background: var(--modern-surface); border-radius: var(--modern-radius);
  box-shadow: var(--modern-shadow); border:1px solid rgba(255,255,255,.06);
  overflow: hidden; transition: transform .08s ease, box-shadow .2s ease;
}
#thumbs_cat dl:hover{ transform: translateY(-2px); }
#thumbs_cat dt a{ border:none; padding:0; background: transparent; }
#thumbs_cat dt img{ aspect-ratio: 4/3; width:100%; height:auto; object-fit: cover; }
#thumbs_cat .title{ padding:10px 12px; max-height:none; line-height:1.4; }
#thumbs_cat .title a{ color: var(--modern-text); }
dl ul.stats{ padding:0 12px 12px; }

/* Items grid */
.thumbs_items{
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(180px,1fr));
  gap: var(--modern-gap);
  margin: 12px 0 0 !important;
}
.thumbs_items dl{
  width: 100% !important; max-width: none !important;
  background: var(--modern-surface); border-radius: var(--modern-radius-sm);
  box-shadow: var(--modern-shadow); border:1px solid rgba(255,255,255,.06);
  overflow: hidden; transition: transform .08s ease, box-shadow .2s ease;
}
.thumbs_items dl:hover{ transform: translateY(-2px); }
.thumbs_items dt a{
  padding-top: 0 !important; width: 100%;
  background: transparent; border: none;
}
.thumbs_items dt a img{
  position: static !important; width: 100%; height: auto; aspect-ratio: 1 / 1; object-fit: cover;
}
.thumbs_items dd span.title{ margin: 0; padding: 10px 12px; text-align: left; }
.thumbs_items ul.stats li{ color: var(--modern-muted); }

/* New/recent badge */
.thumbs_items dt span.new, #thumbs_cat .recent{
  background: linear-gradient(135deg, var(--modern-brand), var(--modern-brand-2)) !important;
  border-radius: 8px; padding:6px 10px;
}

/* Selection check corner */
.thumbs_items dt .selection_icon{
  background: linear-gradient(135deg, var(--modern-brand), var(--modern-brand-2));
  border-radius: 0 12px 0 0;
}

/* ===== Item (viewer) ===== */
#item{
  background: radial-gradient(1200px 600px at 50% -20%, rgba(91,140,255,.18), transparent 60%) , #0c0f16 !important;
  border-radius: 16px; box-shadow: var(--modern-shadow); overflow: hidden;
}
#item img, #item video{ max-height: 78vh !important; }
#item_title.show{ color: var(--modern-text); }
#item_stats{ background: transparent; }
#item_stats li{ color: var(--modern-muted); }

/* Tags */
#item_tags ul li a{
  background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.10);
  color: var(--modern-text); border-radius: 999px; padding:6px 10px;
}

/* ===== Dialog / boxes ===== */
.box_outer{ background: rgba(0,0,0,.55); }
.box_content{
  background: var(--modern-surface); border-top: 3px solid var(--modern-brand);
}
.box_buttons{ background: var(--modern-elev); }

/* ===== Forms (upload/contact/search) ===== */
#upload, #contact_form, form.standard{
  background: var(--modern-surface); padding:18px; border-radius: 16px;
  box-shadow: var(--modern-shadow); border:1px solid rgba(255,255,255,.06);
}
#upload_list{ background: var(--modern-elev); outline-color: rgba(255,255,255,.12); }

/* ===== Pagination ===== */
.pages .link > *{
  background: var(--modern-elev); border:1px solid rgba(255,255,255,.10);
  border-radius: 12px;
}
.pages .link > *::after{ color: var(--modern-text); }

/* ===== Worldmap tweaks ===== */
#worldmap .leaflet-popup-content-wrapper{ background: var(--modern-surface); color: var(--modern-text); }
#worldmap .leaflet-popup-content a{ color: var(--modern-brand); }

/* ===== Responsive typography & spacing ===== */
@media (max-width: 480px){
  :root{ --text-size: 15px; }
  #header_top{ height:56px; }
  #menu li a{ height:50px; }
}
@media (min-width: 1280px){
  :root{ --text-size: 17px; }
  #content{ max-width: 1200px; margin: 0 auto; }
}

/* ===== Accessibility focus ===== */
:where(a,button,[role="button"],input,select,textarea):focus-visible{
  outline: 2px solid var(--modern-brand);
  outline-offset: 2px; border-radius: 10px;
}

/* ===== Optional: subtle hover zoom on thumbs ===== */
#thumbs_cat dt a img, .thumbs_items dt a img{
  transition: transform .25s ease, filter .25s ease;
}
#thumbs_cat dl:hover dt a img, .thumbs_items dl:hover dt a img{
  transform: scale(1.03);
}

/* Keep legacy ids/classes functioning — we only restyle without breaking layout */
