/* ============================================================
   ClickLoc — Design System v2 (modernisé)
   Source unique : tokens + composants + responsive + motion
   ============================================================ */

/* ----- RESET ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
img,svg,video{max-width:100%;display:block}
input,button,textarea,select{font-family:inherit;font-size:inherit;color:inherit}
button{cursor:pointer;-webkit-tap-highlight-color:transparent;background:none;border:none}
a{text-decoration:none;color:inherit}
::selection{background:#d7ddff;color:#14152b}

/* ----- TOKENS ----- */
:root{
  --blue:#2b3170;
  --blue2:#3a42a0;
  --blue3:#5158c8;
  --pale:#eef0fc;
  --pale2:#e4e8fb;
  --gray:#f6f7fb;
  --gray2:#edeef4;
  --line:#e8eaf2;
  --gt:#6b7280;
  --gt2:#9aa1b2;
  --dark:#14152b;
  --white:#fff;
  --green:#16a34a;
  --green-bg:#e7f8ee;
  --red:#dc2626;
  --red-bg:#fef2f2;
  --amber:#f59e0b;
  --amber-bg:#fef6e0;

  --radius:18px;
  --radius-sm:13px;
  --radius-lg:24px;
  --radius-pill:50px;

  --shadow-xs:0 1px 3px rgba(20,21,43,.05);
  --shadow:0 4px 20px rgba(20,21,43,.06),0 1px 4px rgba(20,21,43,.04);
  --shadow-md:0 10px 34px rgba(40,46,105,.10),0 2px 8px rgba(40,46,105,.05);
  --shadow-lg:0 22px 60px rgba(40,46,105,.18);
  --shadow-blue:0 8px 24px rgba(43,49,112,.30);

  --nav-h:66px;
  --top-h:62px;
  --safe-b:env(safe-area-inset-bottom,0px);
  --safe-t:env(safe-area-inset-top,0px);

  --ease:cubic-bezier(.4,0,.2,1);
  --spring:cubic-bezier(.34,1.3,.5,1);
}

body{
  font-family:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--dark);
  background:var(--gray);
  min-height:100vh;
  min-height:100dvh;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  letter-spacing:-.01em;
}

/* ============================================================
   MOTION — entrées & micro-interactions
   ============================================================ */
@keyframes cl-fade{from{opacity:0}to{opacity:1}}
@keyframes cl-up{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes cl-pop{0%{opacity:0;transform:scale(.94)}100%{opacity:1;transform:scale(1)}}

.cl-fade{animation:cl-fade .3s var(--ease) both}
.cl-up{animation:cl-up .45s var(--ease) both}
.cl-pop{animation:cl-pop .4s var(--spring) both}

/* Entrée échelonnée : appliquer .cl-stagger sur un conteneur,
   les enfants directs apparaissent en cascade. */
.cl-stagger>*{animation:cl-up .5s var(--ease) both}
.cl-stagger>*:nth-child(1){animation-delay:.02s}
.cl-stagger>*:nth-child(2){animation-delay:.06s}
.cl-stagger>*:nth-child(3){animation-delay:.10s}
.cl-stagger>*:nth-child(4){animation-delay:.14s}
.cl-stagger>*:nth-child(5){animation-delay:.18s}
.cl-stagger>*:nth-child(6){animation-delay:.22s}
.cl-stagger>*:nth-child(7){animation-delay:.26s}
.cl-stagger>*:nth-child(8){animation-delay:.30s}
.cl-stagger>*:nth-child(n+9){animation-delay:.34s}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar{
  background:rgba(255,255,255,.86);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  backdrop-filter:saturate(180%) blur(14px);
  height:calc(var(--top-h) + var(--safe-t));
  padding-top:var(--safe-t);
  display:flex;align-items:center;justify-content:space-between;
  padding-left:18px;padding-right:18px;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.topbar-logo img{height:38px;width:auto}
.topbar-right{display:flex;align-items:center;gap:11px}

.icon-btn{
  width:44px;height:44px;border-radius:50%;
  background:var(--gray);
  display:flex;align-items:center;justify-content:center;
  position:relative;transition:background .18s var(--ease),transform .12s var(--ease);
}
.icon-btn:active{background:var(--gray2);transform:scale(.92)}
.icon-btn svg{width:21px;height:21px;stroke:var(--blue);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.notif-dot{
  min-width:9px;height:9px;background:var(--red);border-radius:50px;
  position:absolute;top:8px;right:9px;border:2px solid var(--white);
}

.av-sm{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--blue3));color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:700;flex-shrink:0;letter-spacing:0;
}

/* Header avec retour */
.head{
  background:rgba(255,255,255,.86);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  backdrop-filter:saturate(180%) blur(14px);
  height:calc(var(--top-h) + var(--safe-t));
  padding-top:var(--safe-t);
  display:flex;align-items:center;gap:6px;
  padding-left:8px;padding-right:16px;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.back-btn{
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background .18s var(--ease),transform .12s var(--ease);
}
.back-btn:active{background:var(--gray);transform:scale(.92)}
.back-btn svg{width:24px;height:24px;stroke:var(--dark);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.head-title{font-size:18px;font-weight:700;letter-spacing:-.3px}
.head-spacer{flex:1}

/* ============================================================
   LAYOUT
   ============================================================ */
.page{
  max-width:760px;margin:0 auto;width:100%;
  padding:24px 18px calc(var(--nav-h) + 36px + var(--safe-b));
}
.page-narrow{max-width:540px}
.page-title{font-size:26px;font-weight:800;letter-spacing:-.7px;margin-bottom:22px}
.page-sub{font-size:14px;color:var(--gt);margin-top:-16px;margin-bottom:22px}
.sec-title{font-size:13px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--gt2);margin:26px 0 12px}
.sec-title:first-child{margin-top:0}
.muted{color:var(--gt)}
.stack{display:flex;flex-direction:column;gap:14px}
.stack-sm{display:flex;flex-direction:column;gap:10px}

/* ============================================================
   CARDS & ROWS
   ============================================================ */
.card{
  background:var(--white);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;
}
.card-pad{padding:20px}

.list{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.row{
  display:flex;align-items:center;gap:15px;
  padding:17px 18px;border-bottom:1px solid var(--line);
  transition:background .14s var(--ease);width:100%;text-align:left;
}
.row:last-child{border-bottom:none}
.row:active{background:var(--gray)}
.row-ic{
  width:44px;height:44px;border-radius:12px;background:var(--pale);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.row-ic svg{width:20px;height:20px;stroke:var(--blue);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.row-ic.green{background:var(--green-bg)}.row-ic.green svg{stroke:var(--green)}
.row-ic.amber{background:var(--amber-bg)}.row-ic.amber svg{stroke:var(--amber)}
.row-ic.red{background:var(--red-bg)}.row-ic.red svg{stroke:var(--red)}
.row-main{flex:1;min-width:0}
.row-label{font-size:15px;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row-sub{font-size:13px;color:var(--gt);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}
.row-arrow{flex-shrink:0}
.row-arrow svg{width:18px;height:18px;stroke:var(--gt2);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .15s var(--ease)}
.row:active .row-arrow svg{transform:translateX(3px)}
.row-right{font-size:14px;font-weight:600;color:var(--blue);flex-shrink:0}

@media(hover:hover){
  .card,.list{transition:box-shadow .2s var(--ease),transform .2s var(--ease)}
  .tappable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  width:100%;padding:16px 24px;border-radius:14px;
  font-size:16px;font-weight:700;letter-spacing:-.2px;
  transition:transform .12s var(--ease),background .18s var(--ease),box-shadow .18s var(--ease),opacity .18s;
}
.btn:active{transform:scale(.975)}
.btn-primary{background:var(--blue);color:var(--white);box-shadow:var(--shadow-blue)}
.btn-primary:active{background:var(--blue2)}
.btn-primary:disabled{opacity:.55;box-shadow:none}
.btn-outline{background:var(--white);color:var(--blue);box-shadow:inset 0 0 0 2px var(--blue)}
.btn-outline:active{background:var(--pale)}
.btn-ghost{background:var(--gray);color:var(--dark)}
.btn-ghost:active{background:var(--gray2)}
.btn-danger{background:var(--white);color:var(--red);box-shadow:inset 0 0 0 2px var(--red)}
.btn-danger:active{background:var(--red-bg)}
.btn-sm{padding:11px 18px;font-size:14px;width:auto;border-radius:11px}
.btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* Barre d'action fixe en bas (détail objet, réservation) */
.action-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:60;
  background:rgba(255,255,255,.92);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border-top:1px solid var(--line);
  padding:14px 18px calc(14px + var(--safe-b));
  display:flex;align-items:center;gap:14px;
  max-width:760px;margin:0 auto;
}

/* ============================================================
   FORMS
   ============================================================ */
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:8px;color:#3a3f4c}
.input,.textarea,.select{
  width:100%;padding:15px 16px;border:1.5px solid var(--line);
  border-radius:13px;background:var(--white);outline:none;
  font-size:16px;transition:border .16s var(--ease),box-shadow .16s var(--ease);
  -webkit-appearance:none;appearance:none;
}
.input:focus,.textarea:focus,.select:focus{
  border-color:var(--blue);box-shadow:0 0 0 4px rgba(43,49,112,.09);
}
.input.err,.textarea.err,.select.err{border-color:var(--red)}
.input::placeholder,.textarea::placeholder{color:var(--gt2)}
.textarea{resize:vertical;min-height:120px;line-height:1.6}
.select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:42px}
.field-err{font-size:12px;color:var(--red);margin-top:6px;display:none}
.field-err.show{display:block}
.field-hint{font-size:12px;color:var(--gt2);margin-top:6px}

/* Toggle switch */
.switch{position:relative;width:48px;height:28px;flex-shrink:0}
.switch input{opacity:0;width:0;height:0}
.switch .track{position:absolute;inset:0;background:var(--gray2);border-radius:50px;transition:background .2s var(--ease)}
.switch .track::before{content:"";position:absolute;width:22px;height:22px;left:3px;top:3px;background:#fff;border-radius:50%;box-shadow:0 1px 4px rgba(0,0,0,.2);transition:transform .22s var(--spring)}
.switch input:checked+.track{background:var(--blue)}
.switch input:checked+.track::before{transform:translateX(20px)}

/* ============================================================
   CHIPS / FILTERS
   ============================================================ */
.chips{display:flex;gap:9px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{
  padding:9px 17px;border-radius:50px;border:1.5px solid var(--line);
  background:var(--white);font-size:13px;font-weight:600;
  white-space:nowrap;transition:all .16s var(--ease);flex-shrink:0;
}
.chip:active{transform:scale(.95)}
.chip.on{background:var(--blue);border-color:var(--blue);color:var(--white)}

/* ============================================================
   BOTTOM NAV
   ============================================================ */
.bot-nav{
  position:fixed;bottom:0;left:0;right:0;z-index:9000;
  background:rgba(255,255,255,.9);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  backdrop-filter:saturate(180%) blur(16px);
  border-top:1px solid var(--line);
  display:flex;justify-content:space-around;align-items:center;
  height:calc(var(--nav-h) + var(--safe-b));
  padding-bottom:var(--safe-b);
}
.nav-it{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  color:var(--gt2);transition:color .16s var(--ease),transform .12s var(--ease);
  padding:6px 10px;flex:1;
}
.nav-it:active{transform:scale(.9)}
.nav-it.on{color:var(--blue)}
.nav-it svg{width:23px;height:23px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.nav-it span{font-size:10px;font-weight:700;letter-spacing:0}
.nav-add{
  width:56px;height:56px;
  background:linear-gradient(135deg,var(--blue),var(--blue3));border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:var(--shadow-blue);margin-top:-20px;
  transition:transform .14s var(--spring);
}
.nav-add:active{transform:scale(.9)}
.nav-add svg{width:26px;height:26px;stroke:var(--white);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* ============================================================
   EMPTY STATE
   ============================================================ */
.empty{text-align:center;padding:60px 24px}
.empty-ic{
  width:80px;height:80px;border-radius:24px;
  background:linear-gradient(135deg,var(--pale),var(--pale2));
  display:flex;align-items:center;justify-content:center;margin:0 auto 20px;
}
.empty-ic svg{width:34px;height:34px;stroke:var(--blue);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.empty-title{font-size:18px;font-weight:700;margin-bottom:8px}
.empty-sub{font-size:14px;color:var(--gt);max-width:300px;margin:0 auto 22px;line-height:1.6}
.empty-sub a{color:var(--blue);font-weight:700}

/* ============================================================
   BADGES & PILLS
   ============================================================ */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:50px;font-size:11px;font-weight:700}
.badge-blue{background:var(--pale);color:var(--blue)}
.badge-green{background:var(--green-bg);color:var(--green)}
.badge-amber{background:var(--amber-bg);color:#b45309}
.badge-gray{background:var(--gray2);color:var(--gt)}
.badge-red{background:var(--red-bg);color:var(--red)}
.dot-sep{width:3px;height:3px;border-radius:50%;background:currentColor;opacity:.45;display:inline-block;vertical-align:middle;margin:0 2px}

/* ============================================================
   TOAST
   ============================================================ */
#cl-toast{
  position:fixed;left:50%;bottom:calc(30px + var(--safe-b));transform:translateX(-50%) translateY(10px);
  background:var(--dark);color:var(--white);padding:13px 22px;border-radius:50px;
  font-size:14px;font-weight:600;z-index:99999;opacity:0;pointer-events:none;
  transition:opacity .26s var(--ease),transform .26s var(--ease);white-space:nowrap;max-width:90vw;
  box-shadow:var(--shadow-lg);
}
#cl-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ============================================================
   SKELETON / SPINNER
   ============================================================ */
@keyframes cl-shimmer{0%{background-position:-420px 0}100%{background-position:420px 0}}
.skel{background:linear-gradient(90deg,#eef0f5 25%,#e3e6ef 50%,#eef0f5 75%);background-size:840px 100%;animation:cl-shimmer 1.4s infinite linear;border-radius:9px}
@keyframes cl-spin{to{transform:rotate(360deg)}}
.spinner{width:22px;height:22px;border:2.5px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:cl-spin .7s linear infinite}
.spinner-dark{border-color:var(--pale2);border-top-color:var(--blue)}

/* ============================================================
   MODAL / SHEET
   ============================================================ */
.overlay{
  position:fixed;inset:0;background:rgba(20,21,43,.5);z-index:10000;
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .22s var(--ease);
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
}
.overlay.open{opacity:1;pointer-events:all}
.sheet{
  background:var(--white);width:100%;max-width:540px;
  border-radius:26px 26px 0 0;padding:22px 20px calc(24px + var(--safe-b));
  transform:translateY(100%);transition:transform .32s var(--spring);
  max-height:90vh;overflow-y:auto;
}
.overlay.open .sheet{transform:translateY(0)}
.sheet-handle{width:42px;height:5px;background:var(--gray2);border-radius:50px;margin:0 auto 18px}
.sheet-title{font-size:20px;font-weight:800;margin-bottom:6px;letter-spacing:-.4px}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(min-width:640px){
  .page{padding-left:24px;padding-right:24px}
  .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
}
@media(min-width:900px){
  .page{max-width:840px}
}
@media(max-width:380px){
  .page{padding-left:15px;padding-right:15px}
  .page-title{font-size:22px}
  .btn{font-size:15px;padding:15px 20px}
  .input,.textarea,.select{font-size:15px}
  .nav-it span{font-size:9px}
}

/* ============================================================
   MODERN ENHANCEMENTS — plus d'air + animations subtiles
   (override propre, ajouté en fin de feuille)
   ============================================================ */
:root{
  --radius:18px;
  --radius-sm:13px;
  --radius-lg:26px;
  --shadow:0 1px 2px rgba(20,21,43,.04), 0 6px 20px rgba(20,21,43,.05);
  --shadow-md:0 4px 12px rgba(40,46,105,.06), 0 14px 40px rgba(40,46,105,.10);
  --shadow-lg:0 20px 60px rgba(40,46,105,.18);
}

/* Un peu plus d'air dans les pages */
.page{padding-top:24px}
.page-title{margin-bottom:24px}
.sec-title{margin-bottom:16px;margin-top:8px}

/* Cartes : transition douce au tap, plus aérées */
.card{transition:box-shadow .2s ease, transform .15s ease}
.card-pad{padding:20px}
.row{padding:17px 20px}

/* Boutons : lift subtil */
.btn{letter-spacing:-.2px}
.btn-primary{box-shadow:0 6px 18px rgba(40,46,105,.20)}
.btn-primary:active{box-shadow:0 3px 10px rgba(40,46,105,.18)}

/* Chips plus douces */
.chip{transition:transform .12s ease, background .15s ease, border-color .15s ease, color .15s ease}
.chip:active{transform:scale(.96)}

/* Bottom nav : ombre douce vers le haut */
.bot-nav{box-shadow:0 -1px 0 var(--line), 0 -8px 24px rgba(20,21,43,.04)}
.nav-it svg{transition:transform .15s ease}
.nav-it.on svg{transform:translateY(-1px) scale(1.05)}

/* ----- Animations d'entrée ----- */
@keyframes cl-up{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes cl-pop{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.anim-up{animation:cl-up .4s cubic-bezier(.2,.7,.2,1) both}
.anim-pop{animation:cl-pop .35s cubic-bezier(.2,.7,.2,1) both}

/* Stagger : applique un délai croissant aux enfants .stagger > * */
.stagger > *{animation:cl-up .45s cubic-bezier(.2,.7,.2,1) both}
.stagger > *:nth-child(1){animation-delay:.02s}
.stagger > *:nth-child(2){animation-delay:.06s}
.stagger > *:nth-child(3){animation-delay:.10s}
.stagger > *:nth-child(4){animation-delay:.14s}
.stagger > *:nth-child(5){animation-delay:.18s}
.stagger > *:nth-child(6){animation-delay:.22s}
.stagger > *:nth-child(7){animation-delay:.26s}
.stagger > *:nth-child(8){animation-delay:.30s}
.stagger > *:nth-child(n+9){animation-delay:.34s}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* ----- Grille d'objets (réutilisable app + favoris + carte) ----- */
.obj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(min-width:560px){.obj-grid{grid-template-columns:repeat(3,1fr);gap:16px}}
@media(min-width:760px){.obj-grid{grid-template-columns:repeat(4,1fr)}}

.obj-card{
  background:var(--white);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);text-align:left;display:flex;flex-direction:column;
  transition:transform .15s ease, box-shadow .2s ease;
}
.obj-card:active{transform:scale(.98)}
.obj-thumb{
  aspect-ratio:1;background:var(--pale);position:relative;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.obj-thumb img{width:100%;height:100%;object-fit:cover}
.obj-thumb svg{width:38px;height:38px;stroke:var(--blue3);fill:none;stroke-width:1.6;opacity:.5}
.obj-fav{
  position:absolute;top:9px;right:9px;width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.92);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;border:none;
  box-shadow:0 2px 8px rgba(0,0,0,.10);
}
.obj-fav svg{width:18px;height:18px;stroke:var(--blue);fill:none;stroke-width:2}
.obj-fav.on svg{fill:var(--red);stroke:var(--red)}
.obj-info{padding:11px 12px 13px}
.obj-cat{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--blue3)}
.obj-title{font-size:14px;font-weight:700;line-height:1.3;margin:3px 0 6px;
  display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:36px}
.obj-meta{display:flex;align-items:center;justify-content:space-between}
.obj-price{font-size:15px;font-weight:800;color:var(--blue)}
.obj-price small{font-size:11px;font-weight:600;color:var(--gt)}
.obj-rating{font-size:12px;font-weight:600;color:var(--gt);display:flex;align-items:center;gap:3px}
.obj-rating svg{width:13px;height:13px;fill:var(--amber);stroke:none}
