body{
    background:#000;
    color:#fff;
    font-family:Arial,sans-serif;
    margin:0;
    padding:0;
    padding-bottom:140px;
    -webkit-tap-highlight-color:transparent;
}

body.menu-open{
    overflow:hidden;
}

*{
    box-sizing:border-box;
}

a{
    color:#fff;
    text-decoration:none;
}

.page-content{
    padding:90px 20px 20px;
}

h1{
    text-align:center;
    margin:0 0 10px;
    font-size:32px;
}

h2{
    margin:0 0 16px;
}

h3{
    margin:0 0 10px;
}

p{
    line-height:1.5;
}

.date{
    text-align:center;
    color:#999;
    margin-bottom:20px;
    font-size:15px;
}

.date-nav{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:10px;
    margin-bottom:20px;
}

.menu-wrapper{
    position:relative;
    z-index:3000;
}

.menu-toggle{
    position:fixed;
    top:15px;
    left:15px;
    width:48px;
    height:48px;
    border:none;
    border-radius:14px;
    background:#111;
    color:#fff;
    font-size:24px;
    cursor:pointer;
    z-index:3500;
    box-shadow:0 0 10px rgba(0,0,0,0.5);
}

.side-menu{
    position:fixed;
    top:0;
    left:-300px;
    width:270px;
    height:100%;
    background:#111;
    z-index:3400;
    transition:left 0.25s ease;
    overflow-y:auto;
    border-right:1px solid #222;
    padding-bottom:40px;
}

.side-menu.open{
    left:0;
}

.menu-overlay{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,0.7);
    z-index:3300;
    display:none;
}

.menu-overlay.show{
    display:block;
}

.menu-header{
    display:flex;
    align-items:center;
    gap:14px;
    padding:22px 18px;
    border-bottom:1px solid #222;
}

.menu-logo{
    width:52px;
    height:52px;
    border-radius:16px;
    background:#00aa55;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:22px;
    font-weight:bold;
    color:#fff;
}

.menu-title{
    font-size:20px;
    font-weight:bold;
    color:#00ff7b;
}

.menu-subtitle{
    color:#888;
    font-size:13px;
    margin-top:2px;
}

.side-menu a{
    display:block;
    padding:16px 18px;
    border-bottom:1px solid #1f1f1f;
    color:#fff;
    font-size:16px;
    font-weight:bold;
}

.side-menu a:hover{
    background:#1a1a1a;
}

.side-menu a.active{
    background:#00aa55;
    color:#fff;
}

.delete-link{
    color:#ff5555 !important;
}

.food-card,
.quick-added,
.goals-box,
.activity-box,
.scanner-box,
.form-card,
.card{
    background:#111;
    border:1px solid #1d1d1d;
    border-radius:20px;
    padding:18px;
    margin-bottom:18px;
}

.history-card{
    display:block;
}

.history-top{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:10px;
    margin-bottom:12px;
}

.section-title,
.goals-title,
.category-title{
    font-size:22px;
    font-weight:bold;
    margin:30px 0 16px;
}

form{
    width:100%;
}

label{
    display:block;
    margin-bottom:10px;
    color:#bbb;
    font-size:14px;
}

input,
select,
textarea,
.activity-input,
.gram-input{
    width:100%;
    background:#1d1d1d;
    border:1px solid #333;
    border-radius:14px;
    color:#fff;
    padding:14px;
    font-size:16px;
    margin-top:6px;
    margin-bottom:14px;
    outline:none;
}

input:focus,
select:focus,
textarea:focus{
    border-color:#00aa55;
}

textarea{
    resize:vertical;
    min-height:100px;
}

.inline-edit-form{
    margin-top:15px;
}

.delete-form{
    margin-top:12px;
}

.goals-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:12px;
}

button{
    cursor:pointer;
}

.activity-btn,
.goal-save-btn,
.quick-btn,
.small-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:100%;
    border:none;
    border-radius:14px;
    padding:14px;
    font-size:16px;
    font-weight:bold;
    background:#00aa55;
    color:#fff;
    transition:0.2s ease;
}

.activity-btn:hover,
.goal-save-btn:hover,
.quick-btn:hover,
.small-btn:hover{
    opacity:0.9;
}

.small-btn{
    width:auto;
    padding:10px 14px;
    font-size:14px;
}

.quick-btn{
    background:#222;
}

.delete-btn,
.danger-btn{
    width:100%;
    border:none;
    border-radius:14px;
    padding:14px;
    font-size:15px;
    font-weight:bold;
    background:#ff3030;
    color:#fff;
}

.delete-btn:hover,
.danger-btn:hover{
    opacity:0.9;
}

.quick-meals{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
}

.food-kcal,
.balance,
.activity-result,
.bottom-kcal{
    color:#00ff7b;
    font-weight:bold;
}

.food-kcal{
    font-size:26px;
    margin-bottom:10px;
}

.macro-line,
.goal,
.macro-total,
.macro-left{
    color:#bbb;
    font-size:14px;
    line-height:1.6;
}

.food-actions{
    display:flex;
    align-items:center;
    gap:10px;
}

.checkbox{
    width:28px;
    height:28px;
}

.progress-wrapper,
.progress-bg{
    width:100%;
    height:12px;
    background:#1e1e1e;
    border-radius:999px;
    overflow:hidden;
    margin-top:12px;
}

.progress-bar,
.progress-fill{
    height:100%;
    background:#00aa55;
    border-radius:999px;
}

.progress-row{
    margin-bottom:14px;
}

.progress-label{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:8px;
    color:#ccc;
    font-size:14px;
}

.total-bar,
.bottom-summary{
    position:fixed;
    left:0;
    bottom:0;
    width:100%;
    background:#000;
    border-top:1px solid #222;
    padding:16px;
    text-align:center;
    z-index:1000;
}

.total,
.bottom-kcal{
    font-size:28px;
}

.bottom-summary div:last-child{
    margin-top:6px;
    color:#bbb;
    font-size:14px;
}

#reader{
    width:100%;
    overflow:hidden;
    border-radius:18px;
    background:#000;
}

#reader video{
    border-radius:18px;
}

video{
    width:100%;
    max-width:100%;
    background:#000;
    border-radius:18px;
}

canvas{
    max-width:100%;
}

.scanner-box{
    overflow:hidden;
}

.success-message,
.error-message{
    border-radius:16px;
    padding:16px;
    margin-bottom:18px;
    font-weight:bold;
}

.success-message{
    background:#10351f;
    color:#5cff95;
    border:1px solid #1f6b3c;
}

.error-message{
    background:#351010;
    color:#ff7b7b;
    border:1px solid #7a1f1f;
}

.delete-list{
    margin:15px 0;
    padding-left:20px;
    color:#ccc;
}

.delete-list li{
    margin-bottom:8px;
}

@supports(padding:max(0px)){

    body{
        padding-bottom:max(140px, env(safe-area-inset-bottom));
    }

    .bottom-summary{
        padding-bottom:max(16px, env(safe-area-inset-bottom));
    }

}

@media(max-width:700px){

    .page-content{
        padding:90px 14px 14px;
    }

    h1{
        font-size:28px;
    }

    .goals-grid{
        grid-template-columns:1fr;
    }

    .quick-meals{
        grid-template-columns:1fr;
    }

    .history-top{
        flex-direction:column;
        align-items:flex-start;
    }

    .food-kcal{
        font-size:22px;
    }

    .date-nav{
        flex-direction:column;
    }

    .small-btn{
        width:100%;
    }

    .side-menu{
        width:85%;
        left:-85%;
    }

}

.delete-dots-form{
    position:absolute;
    top:14px;
    right:0;
    width:auto;
    margin:0;
    padding:0;
    z-index:20;

}

.dots-btn{
    background:none !important;
    border:none;
    color:#fff !important;
    font-size:26px;
    font-weight:700;
    cursor:pointer;
    padding:0;
    margin:0;
    line-height:1;
    box-shadow:none !important;
    outline:none !important;
    -webkit-tap-highlight-color: transparent;
}

.dots-btn:hover{
    opacity:1;
}

.dots-btn:focus,
.dots-btn:active{
    background:transparent !important;
    color:#ffffff !important;
    outline:none;
    box-shadow:none;
}