
.fitfood-wrap{max-width:1100px;margin:0 auto;padding:16px}
/* Модалка выбора города */
.ffp-city-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99999;display:flex;align-items:center;justify-content:center}
.ffp-city-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);backdrop-filter:blur(2px)}
.ffp-city-modal-content{position:relative;background:#fff;border-radius:16px;padding:32px;max-width:500px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.3);z-index:1}
.ffp-city-modal-content h3{margin:0 0 24px;font-size:20px;text-align:center}
.ffp-city-modal-buttons{display:flex;flex-direction:column;gap:12px}
.ffp-city-modal-btn{background:#16a34a;color:#fff;border:none;border-radius:12px;padding:16px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}
.ffp-city-modal-btn:hover{background:#15803d;transform:translateY(-2px);box-shadow:0 4px 12px rgba(22,163,74,.3)}
.ffp-city-display{display:inline-flex;align-items:center;gap:8px}
.ffp-city-label{color:#6b7280;font-size:14px}
.ffp-city-name{background:transparent;border:none;color:#16a34a;font-size:14px;font-weight:600;cursor:pointer;text-decoration:underline;padding:0}
.ffp-city-name:hover{color:#15803d}
.ffp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:12px;flex-wrap:wrap}
.ffp-calc{width:100%}
.ffp-calc-toggle{background:transparent;border:none;padding:0;cursor:pointer;color:#16a34a;font-size:14px;display:inline-flex;align-items:center;gap:6px;text-decoration:underline}
.ffp-calc-toggle:hover{color:#15803d}
.ffp-calc-toggle::after{content:"\25BC"; /* ▼ */ font-size:10px;color:#6b7280;transition:transform .18s ease}
.ffp-calc-toggle[aria-expanded="true"]::after{transform:rotate(180deg)}
.ffp-calc-panel{margin-top:10px;border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff}
.ffp-calc-grid{display:grid;gap:8px;grid-template-columns:repeat(2, minmax(160px,1fr))}
@media(min-width:900px){.ffp-calc-grid{grid-template-columns:repeat(3, minmax(160px,1fr))}}
.ffp-calc-panel label{display:flex;flex-direction:column;font-size:12px;color:#6b7280}
.ffp-calc-panel input,.ffp-calc-panel select{margin-top:4px;border:1px solid #d1d5db;border-radius:8px}
.ffp-calc-actions{display:flex;gap:8px;margin-top:8px}
.ffp-calc-actions .ffp-calc-run{background:#16a34a;color:#fff;border:none;border-radius:8px;padding:8px 12px;cursor:pointer}
.ffp-calc-actions .ffp-calc-reset{background:#f3f4f6;color:#111827;border:1px solid #e5e7eb;border-radius:8px;padding:8px 12px;cursor:pointer}
.hidden{display:none !important}
.ffp-programs{display:flex;gap:8px;flex-wrap:wrap}
.ffp-program{border:1px solid #e5e7eb;background:#fff;border-radius:16px;padding:10px 14px;cursor:pointer;min-width:140px;text-align:center;display:flex;flex-direction:column;gap:6px;transition:border-color .18s ease, box-shadow .18s ease}
.ffp-program:hover{box-shadow:0 6px 18px rgba(17,24,39,.06)}
.ffp-program.active{border-color:#16a34a;box-shadow:0 0 0 3px rgba(22,163,74,.15)}
.ffp-program-title{font-size:14px;font-weight:700;color:#111827}
.ffp-program-badge{font-size:12px;color:#6b7280}
.ffp-program-recommend{border-color:#ef4444; box-shadow:0 0 0 3px rgba(239,68,68,.18)}
.ffp-pill{border:1px solid #e0e6ef;border-radius:999px;padding:6px 12px;background:#fff;cursor:pointer}
.ffp-pill.active{background:#16a34a;color:#fff;border-color:#16a34a}
.ffp-days{display:flex;gap:10px;overflow:auto;padding:10px 4px;border-bottom:1px dashed #e5e7eb;margin-bottom:12px;align-items:stretch}
.ffp-day{min-width:52px;height:56px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 8px;color:#111827}
.ffp-day-num{font-weight:700;font-size:16px;line-height:1}
.ffp-day-week{font-size:12px;color:#6b7280}
.ffp-day.active{background:#16a34a;color:#fff;border-color:#16a34a}
.ffp-day.active .ffp-day-week{color:#e5edff}
.ffp-day.disabled{opacity:.45;cursor:not-allowed;position:relative}
.ffp-day.disabled::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.1);border-radius:12px}

/* Уведомления */
.ffp-notifications{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px;pointer-events:none}
.ffp-notification{background:#fff;border-radius:12px;padding:16px 20px;box-shadow:0 4px 20px rgba(0,0,0,.15);display:flex;align-items:flex-start;gap:12px;pointer-events:auto;animation:ffp-notification-slide-in .3s ease-out;position:relative;border-left:4px solid #2271b1}
.ffp-notification.error{border-left-color:#d63638}
.ffp-notification.success{border-left-color:#00a32a}
.ffp-notification.warning{border-left-color:#dba617}
.ffp-notification-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:14px;font-weight:bold;color:#fff}
.ffp-notification.error .ffp-notification-icon{background:#d63638}
.ffp-notification.success .ffp-notification-icon{background:#00a32a}
.ffp-notification.warning .ffp-notification-icon{background:#dba617}
.ffp-notification-content{flex:1;min-width:0}
.ffp-notification-title{font-weight:600;font-size:14px;color:#1d2327;margin-bottom:4px}
.ffp-notification-message{font-size:13px;color:#50575e;line-height:1.5}
.ffp-notification-close{flex-shrink:0;width:20px;height:20px;cursor:pointer;opacity:.6;transition:opacity .2s;display:flex;align-items:center;justify-content:center;color:#50575e;font-size:18px;line-height:1}
.ffp-notification-close:hover{opacity:1}
@keyframes ffp-notification-slide-in{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes ffp-notification-slide-out{from{transform:translateX(0);opacity:1}to{transform:translateX(100%);opacity:0}}
.ffp-notification.removing{animation:ffp-notification-slide-out .3s ease-in forwards}
.ffp-body{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:900px){.ffp-body{grid-template-columns:2fr 1fr}}
.ffp-summary{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:8px}
/* KBJU summary refined */
.ffp-summary{display:grid;gap:0;margin-bottom:12px;border:1px solid #e5e7eb;border-radius:12px;background:#fff;overflow:hidden}
@media(min-width:0px){.ffp-summary{grid-template-columns:repeat(2,1fr)}}
@media(min-width:700px){.ffp-summary{grid-template-columns:repeat(4,1fr)}}
.ffp-summary-item{padding:10px 12px;text-align:center;display:flex;flex-direction:column;gap:4px}
.ffp-summary-item + .ffp-summary-item{border-left:1px solid #e5e7eb}
.ffp-summary-label{color:#6b7280;font-size:12px}
.ffp-summary-value{font-weight:700;color:#111827}
.ffp-items{list-style:none;padding:0;margin:0}
/* Grid for cards */
.ffp-grid{display:grid;gap:16px;grid-template-columns:1fr}
@media(min-width:700px){.ffp-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.ffp-grid{grid-template-columns:repeat(3,1fr)}}

/* Card */
.ffp-card{border:1px solid #e5e7eb;border-radius:14px;background:#fff;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 1px 2px rgba(0,0,0,.04);transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.ffp-card:hover,.ffp-card:focus-within{transform:translateY(-2px);box-shadow:0 8px 22px rgba(17,24,39,.08);border-color:#d1d5db}
.ffp-card-top{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;color:#6b7280;font-size:12px}
.ffp-card-meal{font-weight:600;color:#6b7280}
.ffp-card-kcal{color:#9ca3af}
.ffp-card-image{padding:0 12px}
.ffp-card-image img{width:100%;height:auto;display:block;border-radius:10px;transition:transform .25s ease}
.ffp-card:hover .ffp-card-image img,.ffp-card:focus-within .ffp-card-image img{transform:scale(1.03)}
.ffp-card-body{padding:12px}
.ffp-card-title {
    font-weight:600;
    margin-bottom:6px;
    font-size:13px;
    line-height:1.4;
    letter-spacing:.1px;
    text-align: center;
}

.ffp-card-desc{color:#6b7280;font-size:14px}
.ffp-controls{display:grid;gap:12px}
.ffp-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.ffp-durations{display:grid;gap:12px;grid-template-columns:1fr}
@media(min-width:600px){.ffp-durations{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.ffp-durations{grid-template-columns:repeat(3,1fr)}}
.ffp-duration{border:1px solid #e5e7eb;background:#fff;border-radius:14px;padding:12px;cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:4px;position:relative;transition:border-color .18s ease, box-shadow .18s ease;font-size:12px}
.ffp-duration:hover{box-shadow:0 6px 18px rgba(17,24,39,.06)}
.ffp-duration.active{border-color:#16a34a;box-shadow:0 0 0 3px rgba(22,163,74,.15)}
.ffp-duration-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.ffp-badge{position:absolute;top:-8px;right:-8px;background:#16a34a;color:#fff;border-radius:999px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;box-shadow:0 6px 18px rgba(22,163,74,.35)}
.ffp-duration-price{color:#6b7280;font-size:12px}
.ffp-price-old{text-decoration:line-through;color:#9ca3af;margin-right:6px}
.ffp-price-new{font-weight:700;color:#111827}
.ffp-price-suffix{color:#9ca3af}
.ffp-deliveries{margin-top:12px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:14px;padding:12px;color:#4b5563}
.ffp-prices{display:grid;gap:4px;margin-top:8px}
.ffp-order{display:grid;gap:8px;margin-top:12px}
.ffp-order input{padding:8px;border:1px solid #d1d5db;border-radius:8px;width:100%}
.ffp-order-btn{background:#16a34a;color:#fff;border:none;border-radius:10px;padding:12px;cursor:pointer;font-weight:600}
.ffp-order-btn:disabled{opacity:.6}
