@charset "utf-8";

:root {
    --gf-bg: #f5f7fb;
    --gf-card: #ffffff;
    --gf-text: #111827;
    --gf-muted: #6b7280;
    --gf-line: #e5e7eb;
    --gf-primary: #0f766e;
    --gf-primary-soft: #ecfeff;
    --gf-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
    --gf-radius: 24px;
}

#gampo-food-list,
#gampo-food-view,
#bo_w.gampo-shell {
    max-width: 1280px;
    margin: 0 auto;
    color: var(--gf-text);
}

.gampo-shell * {
    box-sizing: border-box;
}

.gampo-shell {
    font-family: "Pretendard", "Noto Sans KR", "Apple SD Gothic Neo", sans-serif;
}

.food-hero,
.food-view-hero,
.food-form-hero {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    align-items: flex-end;
    padding: 32px;
    margin-bottom: 24px;
    border-radius: 32px;
    background: linear-gradient(135deg, #ffffff 0%, #effcf9 100%);
    box-shadow: var(--gf-shadow);
}

.food-hero h2,
.food-view-hero h1,
.food-form-hero h2 {
    margin: 6px 0 10px;
    font-size: 2rem;
    line-height: 1.2;
}

.food-hero p,
.food-form-hero p,
.food-view-hero__address {
    margin: 0;
    color: var(--gf-muted);
    line-height: 1.7;
}

.food-hero__eyebrow,
.food-view-hero__category {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 12px;
    border-radius: 999px;
    background: var(--gf-primary-soft);
    color: var(--gf-primary);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.food-hero__meta,
.food-form-hero__actions,
.food-view-hero__actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
}

.food-hero__meta span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 14px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--gf-line);
    color: var(--gf-muted);
}

.food-category-nav {
    margin-bottom: 22px;
}

#bo_cate_ul {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 0;
    margin: 0;
    list-style: none;
}

#bo_cate_ul li a,
#bo_cate_ul li span {
    display: inline-flex;
    align-items: center;
    padding: 10px 16px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--gf-line);
    color: #374151;
    text-decoration: none;
}

#bo_cate_ul li #bo_cate_on,
#bo_cate_ul li a:hover {
    color: #fff;
    background: var(--gf-primary);
    border-color: var(--gf-primary);
}

.food-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
    padding: 0;
    margin: 0;
    list-style: none;
}

.food-card {
    position: relative;
    overflow: hidden;
    height: 100%;
    border-radius: 26px;
    background: var(--gf-card);
    box-shadow: var(--gf-shadow);
    transition: transform .2s ease, box-shadow .2s ease;
}

.food-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 22px 50px rgba(15, 23, 42, 0.12);
}

.food-card.is-current {
    outline: 2px solid rgba(15, 118, 110, 0.24);
}

.food-card__check {
    position: absolute;
    top: 16px;
    left: 16px;
    z-index: 5;
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: rgba(255,255,255,0.9);
    backdrop-filter: blur(8px);
}

.food-card__thumb {
    position: relative;
    display: block;
    aspect-ratio: 4 / 3;
    background: #ecf0f4;
    overflow: hidden;
}

.food-card__thumb img,
.food-intro-gallery__item img,
.food-content-body img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.food-card__notice {
    position: absolute;
    top: 16px;
    right: 16px;
    z-index: 2;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(17, 24, 39, 0.75);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
}

.food-card__fallback,
.food-empty,
.food-empty-inline,
.food-gallery-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 180px;
    border: 1px dashed var(--gf-line);
    border-radius: 20px;
    color: var(--gf-muted);
    background: #fafafa;
}

.food-card__body {
    padding: 20px;
}

.food-card__topline,
.food-meta-bar {
    display: flex;
    gap: 12px;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.food-card__category {
    font-size: 12px;
    font-weight: 700;
    color: var(--gf-primary);
    text-decoration: none;
}

.food-card__views,
.food-card__address,
.food-card__phone,
.food-card__facts dt,
.food-card__facts dd,
.food-meta-bar {
    color: var(--gf-muted);
}

.food-card__title {
    display: block;
    margin: 10px 0 8px;
    font-size: 1.35rem;
    font-weight: 800;
    line-height: 1.35;
    color: var(--gf-text);
    text-decoration: none;
}

.food-card__phone {
    margin: 0 0 6px;
    font-weight: 700;
}

.food-card__address {
    margin: 0;
    min-height: 44px;
    line-height: 1.6;
}

.food-card__facts {
    display: grid;
    gap: 10px;
    margin: 16px 0 0;
}

.food-card__facts div {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding-top: 10px;
    border-top: 1px solid var(--gf-line);
}

.food-card__facts dt,
.food-card__facts dd,
.food-summary-list dt,
.food-summary-list dd {
    margin: 0;
}

.food-card__badges,
.food-view-hero__chips {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 16px;
}

.gf-badge {
    display: inline-flex;
    align-items: center;
    padding: 8px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}

.gf-badge--parking { background: #eff6ff; color: #1d4ed8; }
.gf-badge--delivery { background: #ecfdf5; color: #047857; }
.gf-badge--takeout { background: #fff7ed; color: #c2410c; }
.gf-badge--default { background: #f3f4f6; color: #374151; }

.gf-admin-bar,
.gf-bottom-bar,
.food-meta-bar {
    margin-top: 20px;
    padding: 16px 20px;
    border-radius: 20px;
    background: #fff;
    border: 1px solid var(--gf-line);
}

.gf-bottom-bar {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.gf-bottom-bar__actions,
.gf-bottom-bar__links {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.gf-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 44px;
    padding: 0 18px;
    border-radius: 14px;
    border: 1px solid var(--gf-line);
    background: #fff;
    color: #111827;
    text-decoration: none;
    cursor: pointer;
    font-weight: 700;
}

.gf-btn--primary {
    border-color: var(--gf-primary);
    background: var(--gf-primary);
    color: #fff;
}

.gf-btn--ghost {
    background: #fff;
}

.gf-btn--sm {
    min-height: 36px;
    padding: 0 12px;
    border-radius: 10px;
    font-size: 13px;
}

/* view */
.food-view-top,
.food-map-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(320px, 1fr);
    gap: 24px;
    margin-bottom: 24px;
}

.food-gallery-card,
.food-summary-card,
.food-section-card,
.food-form-card {
    background: #fff;
    border-radius: 28px;
    padding: 24px;
    box-shadow: var(--gf-shadow);
}

.food-summary-card h2,
.food-section-card__head h2,
.food-form-card__head h3 {
    margin: 0 0 6px;
    font-size: 1.3rem;
}

.food-section-card__head,
.food-form-card__head {
    margin-bottom: 18px;
}

.food-section-card__head p,
.food-form-card__head p {
    margin: 0;
    color: var(--gf-muted);
}

.food-form-card__head--between {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
}

.food-summary-list {
    display: grid;
    gap: 14px;
}

.food-summary-list div {
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 12px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--gf-line);
}

.food-summary-list dt {
    color: var(--gf-muted);
    font-weight: 700;
}

.food-menu-grid,
.food-intro-gallery {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.food-menu-item,
.food-map-box,
.food-file-list li {
    padding: 18px;
    border: 1px solid var(--gf-line);
    border-radius: 18px;
    background: #fff;
}

.food-menu-item {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
}

.food-map-box h3 {
    margin: 0 0 14px;
}

.food-content-body {
    margin-top: 20px;
    line-height: 1.8;
    color: #374151;
}

.food-file-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 12px;
}

.food-file-list li {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

.food-file-list a {
    color: var(--gf-primary);
    text-decoration: none;
    font-weight: 700;
}

/* form */
.food-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.food-form-card--full {
    grid-column: 1 / -1;
}

.food-form-fields {
    display: grid;
    gap: 16px;
}

.food-form-fields--2col {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.gf-field {
    display: grid;
    gap: 8px;
}

.gf-field--full {
    grid-column: 1 / -1;
}

.gf-field > span {
    font-size: 14px;
    font-weight: 700;
    color: #374151;
}

.gf-input,
.gf-select,
.gf-textarea {
    width: 100%;
    min-height: 48px;
    padding: 0 14px;
    border: 1px solid var(--gf-line);
    border-radius: 14px;
    background: #fff;
    color: var(--gf-text);
    font-size: 15px;
}

.gf-textarea {
    min-height: 240px;
    padding: 14px;
}

.gf-input--zip {
    max-width: 120px;
}

.gf-address-tools,
.gf-radio-group,
.gf-phone-grid,
.gf-time-grid,
.gf-option-row,
.gf-form-submit,
.gf-price-wrap {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

.gf-radio-group label,
.gf-option-row label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border: 1px solid var(--gf-line);
    border-radius: 999px;
    background: #fff;
}

.gf-phone-grid > * { flex: 1; }
.gf-phone-grid > select { max-width: 120px; }
.gf-phone-grid--3 > * { max-width: none; }

.food-menu-editor {
    overflow-x: auto;
}

.food-menu-editor__table {
    width: 100%;
    border-collapse: collapse;
}

.food-menu-editor__table th,
.food-menu-editor__table td {
    padding: 12px;
    border-bottom: 1px solid var(--gf-line);
    text-align: left;
    vertical-align: middle;
}

.food-upload-list {
    display: grid;
    gap: 14px;
}

.food-upload-row {
    display: grid;
    gap: 10px;
    padding: 16px;
    border: 1px solid var(--gf-line);
    border-radius: 18px;
}

.food-upload-row__existing {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
    color: var(--gf-muted);
}

.gf-form-submit {
    margin-top: 24px;
    justify-content: flex-end;
}

#bo_v_share,
#bo_vc {
    margin-top: 24px;
}

#bo_vc,
#bo_vc_w,
#bo_vc > article,
#bo_vc .cmt_lst,
#bo_vc .cmt_lst li,
#bo_vc #cmt_write {
    border-radius: 20px;
}

/* responsive */
@media (max-width: 1024px) {
    .food-grid,
    .food-form-grid,
    .food-menu-grid,
    .food-view-top,
    .food-map-grid,
    .food-form-fields--2col {
        grid-template-columns: 1fr 1fr;
    }

    .food-view-top,
    .food-map-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .food-grid,
    .food-form-grid,
    .food-menu-grid,
    .food-form-fields--2col,
    .food-intro-gallery {
        grid-template-columns: 1fr;
    }

    .food-hero,
    .food-view-hero,
    .food-form-hero,
    .food-gallery-card,
    .food-summary-card,
    .food-section-card,
    .food-form-card {
        padding: 18px;
        border-radius: 22px;
    }

    .food-hero h2,
    .food-view-hero h1,
    .food-form-hero h2 {
        font-size: 1.6rem;
    }

    .food-summary-list div {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    .food-card__title {
        font-size: 1.15rem;
    }

    .gf-bottom-bar,
    .food-meta-bar,
    .food-form-card__head--between {
        flex-direction: column;
        align-items: stretch;
    }

    .gf-btn,
    .gf-btn--primary,
    .gf-btn--ghost {
        width: 100%;
    }
}


/* comment area */
.sound_only {
    position: absolute !important;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.cmt_btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border: 1px solid var(--gf-line);
    border-radius: 999px;
    background: #fff;
    color: var(--gf-text);
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
}

#bo_vc {
    margin-top: 18px;
    display: grid;
    gap: 14px;
}

#bo_vc_empty {
    margin: 0;
    padding: 24px;
    text-align: center;
    color: var(--gf-muted);
    border: 1px dashed var(--gf-line);
    border-radius: 20px;
    background: #fff;
}

#bo_vc > article {
    background: #fff;
    border: 1px solid var(--gf-line);
    padding: 20px;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
}

#bo_vc > article + article {
    margin-top: 0;
}

#bo_vc > article > header {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px 12px;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--gf-line);
}

#bo_vc > article > header .sv_member,
#bo_vc > article > header .sv_guest,
#bo_vc > article > header > span:first-of-type,
#bo_vc > article > header > a:first-of-type,
#bo_vc > article > header strong {
    font-weight: 700;
    color: var(--gf-text);
}

.bo_vc_hdinfo {
    color: var(--gf-muted);
    font-size: .94rem;
}

.cmt_contents p {
    margin: 0;
    color: var(--gf-text);
    line-height: 1.75;
    word-break: keep-all;
}

.bo_vc_act {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 16px 0 0;
    padding: 0;
    list-style: none;
}

.bo_vc_act a,
.btn_b03,
.btn_submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 14px;
    border-radius: 12px;
    border: 1px solid var(--gf-line);
    background: #fff;
    color: var(--gf-text);
    text-decoration: none;
    font-weight: 700;
    transition: .2s ease;
}

.bo_vc_act a:hover,
.btn_b03:hover {
    background: #f8fafc;
    transform: translateY(-1px);
}

#bo_vc_w {
    margin-top: 18px;
    padding: 22px;
    background: #fff;
    border: 1px solid var(--gf-line);
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
}

#bo_vc_w h2 {
    margin: 0 0 14px;
    font-size: 1.35rem;
}

#fviewcomment {
    display: grid;
    gap: 14px;
}

#char_cnt {
    justify-self: end;
    color: var(--gf-muted);
    font-size: .92rem;
}

#wr_content,
.frm_input,
#bo_vc_w input[type="text"],
#bo_vc_w input[type="password"],
#bo_vc_w textarea {
    width: 100%;
    border: 1px solid var(--gf-line);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
    color: var(--gf-text);
    font-size: 1rem;
    box-sizing: border-box;
}

#wr_content,
#bo_vc_w textarea {
    min-height: 140px;
    resize: vertical;
    line-height: 1.7;
}

.bo_vc_w_wr {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-end;
    flex-wrap: wrap;
}

.bo_vc_w_info {
    flex: 1 1 320px;
    display: grid;
    gap: 10px;
}

.btn_confirm {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.btn_confirm label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 12px;
    border: 1px solid var(--gf-line);
    background: #fff;
    cursor: pointer;
}

.btn_submit,
#btn_submit {
    min-width: 120px;
    border: 0;
    background: linear-gradient(135deg, #0f766e, #14b8a6);
    color: #fff;
    box-shadow: 0 10px 24px rgba(20, 184, 166, 0.28);
}

.btn_submit:hover,
#btn_submit:hover {
    transform: translateY(-1px);
}

#bo_vc_w .captcha,
#bo_vc_w #captcha {
    margin-top: 4px;
}

#bo_vc .bo_vc_w {
    margin-top: 14px;
}

@media (max-width: 768px) {
    #bo_vc > article,
    #bo_vc_w {
        padding: 16px;
        border-radius: 18px;
    }

    .bo_vc_w_wr,
    .btn_confirm {
        flex-direction: column;
        align-items: stretch;
    }

    .btn_confirm label,
    .btn_submit,
    #btn_submit,
    .bo_vc_act a {
        width: 100%;
    }
}


/* premium review ui */
.food-review-toggle { margin-top: 18px; }
.food-review-wrap {
    margin-top: 16px;
    display: grid;
    gap: 18px;
}
.food-review-head,
.food-review-form {
    position: relative;
    overflow: hidden;
}
.food-review-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 24px 26px;
    border: 1px solid var(--gf-line);
    border-radius: 24px;
    background: linear-gradient(135deg, #ffffff, #f0fdfa);
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.06);
}
.food-review-head h2,
.food-review-form h2 { margin: 4px 0 6px; font-size: 1.55rem; }
.food-review-head p,
.food-review-form p { margin: 0; color: var(--gf-muted); }
.food-review-head__eyebrow {
    display: inline-block;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(20, 184, 166, 0.12);
    color: #0f766e;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .08em;
}
.food-review-summary {
    min-width: 200px;
    padding: 18px 20px;
    border-radius: 20px;
    background: #fff;
    border: 1px solid rgba(20, 184, 166, 0.18);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.6);
    text-align: center;
}
.food-review-summary strong,
.food-review-summary span { display:block; }
.food-review-summary strong { font-size: 1.15rem; margin-bottom: 4px; }
.food-review-summary span { color: var(--gf-muted); font-size: .92rem; }
.food-review-summary__stars,
.food-review-stars,
.food-review-form__stars {
    letter-spacing: .18em;
    color: #f59e0b;
}
.food-review-summary__stars { font-size: 1.1rem; margin-bottom: 8px; }
.food-review-stars { font-size: .95rem; }
.food-review-card.is-reply {
    background: linear-gradient(135deg, #ffffff, #f8fafc);
    border-color: #dbeafe !important;
}
#bo_vc > article.food-review-card {
    padding: 22px;
    border-radius: 24px;
}
#bo_vc > article.food-review-card > header {
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
}
.food-review-user {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    flex: 1;
}
.food-review-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 16px;
    background: linear-gradient(135deg, #0f766e, #14b8a6);
    color: #fff;
    font-weight: 800;
    font-size: 1rem;
    box-shadow: 0 12px 24px rgba(20, 184, 166, .22);
    flex: 0 0 48px;
}
.food-review-user__meta { display:grid; gap: 4px; }
.food-review-user__meta strong { font-size: 1.04rem; }
.food-review-user__top,
.food-review-submeta {
    display: flex;
    align-items: center;
    gap: 8px 10px;
    flex-wrap: wrap;
}
.food-review-badge,
.food-review-index,
.food-review-title,
.food-review-form__guide span,
.food-review-form__guide em {
    display: inline-flex;
    align-items: center;
}
.food-review-badge {
    padding: 6px 10px;
    border-radius: 999px;
    background: #ecfeff;
    color: #0f766e;
    font-size: .8rem;
    font-weight: 700;
}
.food-review-index {
    color: var(--gf-muted);
    font-size: .82rem;
}
.food-review-submeta {
    color: var(--gf-muted);
    font-size: .92rem;
}
.food-review-title {
    margin-bottom: 10px;
    padding: 8px 12px;
    border-radius: 12px;
    background: #f8fafc;
    color: var(--gf-text);
    font-weight: 700;
    font-size: .92rem;
}
.food-review-card .cmt_contents p {
    font-size: 1rem;
    line-height: 1.85;
}
.food-review-card .bo_vc_act { margin-top: 18px; }
.food-review-card .bo_vc_act a {
    border-radius: 999px;
    padding: 0 16px;
}
.food-review-form {
    padding: 24px;
    border-radius: 24px;
    background: linear-gradient(180deg, #ffffff, #f8fafc);
}
.food-review-form__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    margin-bottom: 16px;
}
.food-review-form__stars {
    padding: 12px 14px;
    border-radius: 16px;
    background: #fff7ed;
    font-size: 1.15rem;
}
.food-review-form__guide {
    display: flex;
    align-items: center;
    gap: 8px 10px;
    flex-wrap: wrap;
    padding: 12px 14px;
    border-radius: 16px;
    background: #fff;
    border: 1px dashed var(--gf-line);
}
.food-review-form__guide span {
    font-weight: 800;
    color: var(--gf-text);
}
.food-review-form__guide em {
    color: var(--gf-muted);
    font-style: normal;
}
#bo_vc_wrap #bo_vc,
#bo_vc_wrap #bo_vc_w { margin-top: 0; }
@media (max-width: 768px) {
    .food-review-head,
    .food-review-form__head,
    #bo_vc > article.food-review-card > header {
        flex-direction: column;
        align-items: stretch;
    }
    .food-review-summary,
    .food-review-form__stars { width: 100%; }
    .food-review-user { gap: 12px; }
    .food-review-avatar { width: 44px; height: 44px; border-radius: 14px; }
}


/* review system upgrade */
.food-review-summary__score{font-size:32px;font-weight:800;line-height:1;color:#0f172a}
.food-review-top-points{display:flex;gap:14px;align-items:flex-start;justify-content:space-between;padding:18px 22px;margin:0 0 22px;background:#fff;border:1px solid #e5e7eb;border-radius:20px;box-shadow:0 10px 30px rgba(15,23,42,.04)}
.food-review-top-points strong{display:block;padding-top:4px;color:#111827}
.food-review-top-points__chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.food-review-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0 0 16px}
.food-review-meta-row{background:#f8fafc;border:1px solid #e5edf5;border-radius:16px;padding:12px 14px;display:flex;flex-direction:column;gap:6px}
.food-review-meta-row--full{grid-column:1/-1}
.food-review-meta-label{font-size:12px;font-weight:700;color:#64748b}
.food-review-meta-row strong{font-size:15px;color:#0f172a}
.food-review-chip-wrap{display:flex;gap:8px;flex-wrap:wrap}
.food-review-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;background:#f1f5f9;border:1px solid #dbe5ef;color:#0f172a;font-size:13px;font-weight:700}
.food-review-chip em{font-style:normal;color:#0ea5a4}
.food-review-chip.is-selected{background:#ecfeff;border-color:#99f6e4;color:#0f766e}
.food-review-stars{display:flex;align-items:center;gap:8px;font-weight:700;color:#f59e0b}
.food-review-stars__score{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:32px;border-radius:999px;background:#fff7ed;color:#c2410c;font-size:13px;font-weight:800;padding:0 10px}
.food-review-card.is-real-review{border-color:#d9f2ee;box-shadow:0 16px 40px rgba(15,23,42,.05)}
.food-review-editor{display:grid;gap:18px;margin:0 0 18px}
.food-review-editor__label{display:block;margin-bottom:10px;font-size:14px;font-weight:800;color:#111827}
.food-review-rating-box,.food-review-points-box{padding:18px;border:1px solid #e5e7eb;border-radius:18px;background:#fff}
.food-rating-select{display:flex;gap:10px;flex-wrap:wrap}
.food-rating-star{width:46px;height:46px;border-radius:14px;border:1px solid #e5e7eb;background:#fff;color:#cbd5e1;font-size:24px;cursor:pointer;transition:.2s ease}
.food-rating-star:hover,.food-rating-star.is-active{background:#fff7ed;border-color:#fdba74;color:#f59e0b;transform:translateY(-1px)}
.food-rating-caption{display:block;margin-top:10px;color:#64748b;font-size:13px}
.food-review-chip-picker{display:flex;gap:10px;flex-wrap:wrap}
.food-review-point-btn{padding:12px 16px;border-radius:999px;border:1px solid #dbe5ef;background:#fff;color:#334155;font-size:14px;font-weight:700;cursor:pointer;transition:.2s ease}
.food-review-point-btn:hover,.food-review-point-btn.is-active{background:#0f766e;color:#fff;border-color:#0f766e;box-shadow:0 8px 20px rgba(15,118,110,.18)}
.food-review-extra-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.food-review-input{display:flex;flex-direction:column;gap:8px}
.food-review-input span{font-size:14px;font-weight:800;color:#111827}
.food-review-input input,.food-review-input select{height:48px;padding:0 14px;border:1px solid #dbe5ef;border-radius:14px;background:#fff;color:#111827}
.food-review-input input:focus,.food-review-input select:focus{outline:none;border-color:#14b8a6;box-shadow:0 0 0 4px rgba(20,184,166,.12)}
@media (max-width: 768px){
  .food-review-top-points{flex-direction:column}
  .food-review-top-points__chips{justify-content:flex-start}
  .food-review-meta-grid,.food-review-extra-grid{grid-template-columns:1fr}
  .food-rating-star{width:42px;height:42px}
}

/* =========================================
   °¨Æ÷ ¸ÀÁý ½ºÅ² ¸ð¹ÙÀÏ ±úÁü ¹æÁö Á¤¸®º»
   style.css ÇÏ´Ü¿¡ Ãß°¡
========================================= */

/* 1) ÀüÃ¼ ¹Ú½º °è»ê ¾ÈÁ¤È­ */
#gampo-food-view,
#gampo-food-view * {
    box-sizing: border-box;
}

/* 2) °øÅë ¹Ìµð¾î ¿ä¼Ò ³ÑÄ§ ¹æÁö */
#gampo-food-view img,
#gampo-food-view video,
#gampo-food-view canvas,
#gampo-food-view svg,
#gampo-food-view iframe {
    max-width: 100%;
    height: auto;
}

/* Ä«Ä«¿À¸Ê/·Îµåºä ³»ºÎ Äµ¹ö½º º¸Á¤ */
#gampo-food-view #map,
#gampo-food-view #gf-map,
#gampo-food-view #gf-roadview,
#gampo-food-view .gf-map-canvas,
#gampo-food-view .gf-road-canvas {
    width: 100% !important;
    max-width: 100% !important;
}

/* 3) ¿¹Àü Å×ÀÌºí ±â¹Ý ÄÚµå ´ëÀÀ */
#gampo-food-view table {
    width: 100% !important;
    max-width: 100% !important;
    table-layout: fixed;
}

#gampo-food-view td,
#gampo-food-view th {
    word-break: break-word;
}

/* °¶·¯¸® ±¸Çü ±¸Á¶ ´ëÀÀ */
#gampo-food-view .b_box,
#gampo-food-view .s_box {
    width: 100% !important;
    max-width: 100% !important;
}

#gampo-food-view .b_box img,
#gampo-food-view .s_box img {
    max-width: 100% !important;
    height: auto !important;
}

/* 4) »ó¼¼ÆäÀÌÁö ÇÙ½É ·¹ÀÌ¾Æ¿ô °øÅë */
.food-view-top,
.food-info-grid,
.food-review-section,
.food-gallery-card,
.food-map-card,
.food-detail-card,
.food-meta-card,
.food-review-card,
.food-review-form,
.food-map-grid,
.food-map-box {
    min-width: 0;
    max-width: 100%;
}

/* Ä«µå ³»ºÎ ±ä ¿ä¼Ò ³ÑÄ§ ¹æÁö */
.food-view-hero,
.food-view-hero__copy,
.food-view-hero__actions,
.food-view-hero__chips,
.food-detail-list,
.food-detail-list li,
.food-review-meta,
.food-review-body,
.food-review-tags,
.food-review-points {
    min-width: 0;
    overflow-wrap: break-word;
    word-break: keep-all;
}

/* 5) »ó´Ü È÷¾î·Î ¿µ¿ª */
.food-view-hero {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
}

.food-view-hero__copy {
    flex: 1 1 auto;
    min-width: 0;
}

.food-view-hero__actions {
    flex: 0 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.food-view-hero__actions a,
.food-view-hero__actions button {
    white-space: nowrap;
}

/* 6) °¶·¯¸®/º»¹® Ä«µå */
.food-gallery-card,
.food-detail-card,
.food-map-box,
.food-review-card,
.food-review-form {
    width: 100%;
    overflow: hidden;
}

/* 7) Áöµµ/·Îµåºä 2¿­ -> ¸ð¹ÙÀÏ 1¿­ */
.food-map-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
    align-items: start;
    width: 100%;
    max-width: 100%;
}

.food-map-box {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
    background: #fff;
    border: 1px solid #e9eef3;
    border-radius: 20px;
    padding: 18px;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.04);
}

.food-map-box > h3 {
    margin: 0 0 12px;
    font-size: 18px;
    line-height: 1.35;
    font-weight: 700;
    color: #111827;
}

.food-map-box .gf-map-card,
.food-map-box .gf-road-card,
.food-map-box .gf-map-box,
.food-map-box .gf-road-box,
.food-map-box .gf-map-canvas,
.food-map-box .gf-road-canvas {
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.food-map-box .gf-map-box,
.food-map-box .gf-road-box,
.food-map-box .gf-map-canvas,
.food-map-box .gf-road-canvas {
    overflow: hidden;
    border-radius: 16px;
}

/* 8) ¸®ºä/´ñ±Û ¿µ¿ª */
.food-review-section {
    width: 100%;
}

.food-review-card,
.food-review-form {
    width: 100%;
    max-width: 100%;
}

.food-review-points,
.food-review-tags,
.food-review-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.food-review-points button,
.food-review-tags button,
.food-review-actions a,
.food-review-actions button {
    max-width: 100%;
}

/* 9) ¹öÆ°/Ä¨ °è¿­ ÁÙ¹Ù²Þ ¾ÈÁ¤È­ */
.gf-btn,
.gf-badge,
.food-chip,
.review-chip,
.review-point-chip {
    max-width: 100%;
}

.food-view-hero__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

/* 10) ¸ð¹ÙÀÏ ´ëÀÀ */
@media (max-width: 991px) {
    .food-map-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
}

@media (max-width: 768px) {
    #gampo-food-view {
        overflow-x: hidden;
    }

    .food-view-hero {
        display: block;
    }

    .food-view-hero__actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 10px;
        margin-top: 14px;
    }

    .food-view-hero__actions a,
    .food-view-hero__actions button {
        width: 100%;
        text-align: center;
    }

    .food-view-top,
    .food-info-grid {
        display: block;
    }

    .food-gallery-card,
    .food-map-card,
    .food-detail-card,
    .food-meta-card,
    .food-review-card,
    .food-review-form,
    .food-map-box {
        width: 100%;
        margin-bottom: 16px;
    }

    .food-map-box {
        padding: 14px;
        border-radius: 16px;
    }

    .food-map-box > h3 {
        font-size: 16px;
        margin-bottom: 10px;
    }

    .food-map-box .gf-map-canvas,
    .food-map-box .gf-road-canvas,
    #gampo-food-view #map,
    #gampo-food-view #gf-map,
    #gampo-food-view #gf-roadview {
        min-height: 220px !important;
    }

    .food-view-hero__chips,
    .food-review-points,
    .food-review-tags,
    .food-review-actions {
        gap: 6px;
    }
}

/* 11) ¾ÆÁÖ ÀÛÀº ¸ð¹ÙÀÏ */
@media (max-width: 480px) {
    .food-view-hero__actions {
        grid-template-columns: 1fr;
    }

    .food-map-box,
    .food-gallery-card,
    .food-detail-card,
    .food-review-card,
    .food-review-form {
        border-radius: 14px;
    }

    .food-map-box .gf-map-canvas,
    .food-map-box .gf-road-canvas {
        min-height: 200px !important;
    }
}