/*
Theme Name: AhmedTea
Author: Your Name
Author URI: Your Website
Description: A custom theme for Ahmed Tea.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ahmedtea
Domain Path: /languages
*/
/* --- Color Palette Variables --- */
@font-face {
    font-family: 'PingArLt';
    src: url('../fonts/PingARLT-Regular.woff2') format('woff2'),
        url('../fonts/PingARLT-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'PingArLt';
    src: url('../fonts/PingARLT-Bold.woff2') format('woff2'),
        url('../fonts/PingARLT-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

:root {
    --color-background-body: #F8F9FA;
    --color-text-body: #000000;
    --color-link: #2c5530;
    
    --color-topbar-bg: #1D1F1F;
    --color-topbar-text: #FFFFFF;

    /* Header uses white for icons/text against its transparent/intro background */
    --color-header-icons: #FFFFFF; 
    
    --color-intro-bg: #F0F0F0; /* Used as fallback behind cover image */

    --color-post-bg: #FFFFFF;
    --color-post-border: #DDDDDD;
    
    --color-footer-bg: #EFF0F2;
    --color-footer-text: #000000;

    --color-copyright-bg: #F9FAFB;
    --color-copyright-text: #374151;
    
    --max-width: 1440px;
    --tablet-breakpoint: 992px; /* New breakpoint for drawer menu and content stacking */
}

/* --- Base Styles and Global Utilities --- */
body {
    font-family: 'PingArLt', sans-serif;
    background: var(--color-background-body);
    color: var(--color-text-body);
    margin: 0;
    font-size: 15px;
    font-weight: 400;
    line-height: 26px;
}

/* ADDED: Global class to disable body scrolling when drawer or search is open */
.no-scroll {
    overflow: hidden !important;
}

.container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 15px;
}

a {
    color: var(--color-link);
    text-decoration: none;
    transition: color 0.3s;
}

a:hover {
    color: #4a7c50; 
}

/* Global List Reset (for menus and widgets) */
.top-bar-menu ul,
.main-navigation ul,
.footer-column ul{
    list-style: none;
    margin: 0;
    padding: 0;
}

/* --- [1] Top Bar --- */
.top-bar {
    background: var(--color-topbar-bg);
    color: var(--color-topbar-text);
    font-size: 0.9em;
    padding: 8px 0;
    border-bottom: 1px solid hsla(0, 0%, 93%, .349);
    min-height: 36px;
    padding-bottom: .5rem;
    padding-top: .5rem;
    align-content: center;
}

@media (min-width: 1024px) {
    .top-bar {
        padding-bottom: .375rem;
        padding-top: .375rem;
    }
}

.top-bar .top-bar-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.top-bar-contact span {
    border-right: 1px solid rgba(209,213,219,.1);
    border-left: 1px solid rgba(209,213,219,.1);
    display: inline-block;
    font-size: .875rem;
    line-height: 1;
    padding: .125rem .5rem;
    transition: all .3s;
}
.top-bar-contact span:first-child {
    padding-left: 0;
    border-right-width: 0;
}
[dir="rtl"] .top-bar-contact span:first-child {
    padding-left: .5rem;
    padding-right: 0;
    border-right: 0;
}
.top-bar-contact span:last-child {
    padding-right: 0;
    border-right: 0;
}
[dir="rtl"] .top-bar-contact span:last-child {
    padding-right: .5rem;
    padding-left: 0;
    border-left: 0;
}

@media (min-width: 1024px) {
    [dir="rtl"] .top-bar-contact span:first-child {
        padding-left: 1rem;
    }
    [dir="rtl"] .top-bar-contact span:last-child {
        padding-right: 1rem;
    }
    .top-bar-contact span, [dir="rtl"] .top-bar-contact span {
        padding: 0 1rem;
    }
}

.top-bar a {
    color: var(--color-topbar-text);
}

.top-bar-menu ul li {
    display: inline-block;
    margin-inline-start: 15px;
}
.top-bar-menu ul li:last-child {
    margin-inline-start: 0;
}
.top-bar-menu ul li [class^="sicon-"]{
    margin-inline-end: 6px;
}

/* --- [2] Header --- */
.header-sec {position: relative;}
.site-header {
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    box-shadow: 0 0 5px rgba(0, 0, 0, .1);
    position: absolute; /* Achieves 'fixed over intro section' effect */
    top: 0;
    z-index: 990;
    width: 100%;
    transition: background-color 0.3s;
}
@media(max-width:768px){
    .site-header:not(.mobile-header-fixed){
        backdrop-filter: blur(0);
        -webkit-backdrop-filter: blur(0);
    }
    .site-header.mobile-header-fixed{
        backdrop-filter: blur(40px);
        -webkit-backdrop-filter: blur(40px);
    }
}

.header-utility-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 10px;
}

.site-branding {
    text-align: center;
    flex-grow: 1;
}

.custom-logo {
    max-width: 150px;
    height: 48px;
}

.header-icons {
    display: flex;
    gap: 10px;
}

.header-icons .icon-button {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--color-header-icons);
    padding: 5px;
    align-items: center;
    display: flex;
    font-size: 1.25rem;
    height: 2.5rem;
    justify-content: center;
    line-height: 1.75rem;
    width: 2.5rem;
}

.mobile-header-fixed .header-icons .icon-button{
    color: var(--color-text-body);
}

.header-icons .menu-toggle, .header-icons .empty-button {
    display: none; /* Hidden on desktop, shown in @media block */
}

/* --- Search Container (Fixed Overlay) --- */
.search-form-container {
    background-color: #6b7280;
    background-color: rgba(107, 114, 128, .75);
    bottom: 0;
    left: 0;
    position: fixed;
    right: 0;
    top: 0;
    --tw-bg-opacity: 0.75;
    transition-duration: .2s;
    transition-property: opacity;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    transition-timing-function: cubic-bezier(.4, 0, 1, 1);
    width: 100%;
    height: 100%;
    display: none; 
    z-index: 10000;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    transform: translateY(-100%);
    transition: transform 0.3s ease-in-out;
}
.search-form-container.is-active {
    --tw-translate-y: 0px;
    opacity: 1;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    transition-duration: .3s;
    transition-timing-function: cubic-bezier(0, 0, .2, 1);
    display: flex;
    transform: translateY(0);
}

.search-form{
    width: 100%;
    text-align: center;
    max-width: 80%;
    margin:0 auto;
}

.search-field {
    max-width: 600px;
    border-radius: .375rem;
    height: 3.5rem;
    width: 100%;
    border: 0px;
    font-family: 'PingArLt';
    background-color: var(--color-background-body);
    font-size: .875rem;
    line-height: 1.25rem;
    padding: 0 2.5rem .125rem .5rem;
    color: var(--color-text-body);
    color: rgba(75, 85, 99, var(--tw-text-opacity, 1));
    transition-duration: .3s;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    border: 1px solid rgba(107, 114, 128, .25);
}
.search-field:focus,.search-field:focus-visible{
    border:0;
    outline:0;
}

.search-submit{display:none;}

.close-search {
    position: absolute;
    inset-inline-end: 20px;
    top: 20px;
    background: none;
    border: none;
    font-size: 2rem;
    color: var(--color-header-icons);
    cursor: pointer;
}

/* --- [2] Primary Navigation (Desktop Mode) --- */
.main-navigation {
    text-align: center;
    padding-bottom: 15px;
}

.main-navigation .menu-control{
    justify-content: space-between;
    align-items: center;
    display: none;
}

.main-navigation .nav-menu {
    display: flex;
    justify-content: center;
}

.main-navigation a {
    display: block;
    text-transform: uppercase;
    font-weight: bold;
    color: var(--color-header-icons);
    align-items: center;
    font-size: .875rem;
    justify-content: space-between;
    line-height: 1.25rem;
    padding: .75rem;
}
@media only screen and (min-width: 1024px) {
    .main-navigation a {
        font-weight: 700;
        padding-top: 0;
    }
}

/* --- [3] Intro Section --- */
.intro-section {
    position: relative;
    /* padding: 150px 0; */
    color: #fff;
    text-align: center;
    overflow: hidden;
    background-color: var(--color-intro-bg);
    background-size: cover;
    background-position: center center;
    height:calc(80vh - 49px);
    /* Apply desktop background by default */
    background-image: var(--cover-bg-desktop, url('../images/introbg.webp'));
    align-items: center;
    display: flex;
}

@media (max-width: 768px) {
    .intro-section{
        height:65vh;
        /* Apply mobile background on smaller screens */
        background-image: var(--cover-bg-mobile, url('../images/introbg-mobile.webp'));
    }
}

.intro-content {
    max-width: 800px;
    margin: 0 auto;
    background: rgba(19, 19, 19, .8);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    padding: clamp(24px, 5vw, 56px);
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, .1);
    box-shadow: 0 8px 32px rgba(0, 0, 0, .3), 0 4px 16px rgba(0, 0, 0, .2), inset 0 1px 0 rgba(255, 255, 255, .1);
    transition: .3s cubic-bezier(.4, 0, .2, 1);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    position: relative;
    z-index: 1;
}

.intro-section .entry-title {
    font-size: 2rem;
    font-weight: 700;
    margin-top: 0;
    margin-bottom: 1rem;
    line-height: 1.5;
}

.intro-content .entry-title:only-child {
    margin-bottom: 0;
}

@media (min-width: 1024px) {
    .intro-section .entry-title {
        font-size: 3rem;
        line-height: 1.5;
    }
}

.entry-summary {
    font-size: 1rem;
    line-height: 1.5rem;
    margin-block-start: 1em;
    margin-block-end: 1em;
}
@media (min-width: 1024px) {
    .entry-summary {
        font-size: 1.125rem;
        line-height: 1.75rem;
    }
}
@media (min-width: 1280px) {
    .entry-summary {
        font-size: 1.25rem;
        line-height: 1.75rem;
    }
}

.button {
    display: inline-block;
    padding: 12px 30px;
    font-size: 1.2em;
    background: var(--color-link);
    color: #fff;
    border-radius: 5px;
    text-transform: uppercase;
    font-weight: bold;
    transition: background-color 0.3s;
}

.button:hover {
    background: #FFFFFF;
}

/* --- [5] Footer --- */
.site-footer {
    background: var(--color-footer-bg);
    color: var(--color-footer-text);
    position: relative;
    padding-bottom: 20px;
}
.site-footer .footer-curve {
    color: var(--color-footer-bg);
    position: absolute;
    width: 100%;
    height: 1rem;
    margin-top: -1rem;
    top: 0;
    right:0;
    left:0;
}

@media (min-width: 640px) {
    .site-footer {
        margin-top: 5rem;
    }
    .site-footer .footer-curve {
        height: 4rem;
        margin-top: -4rem;
    }
}

.footer-list a {
    display: block;
    font-size: .75rem;
    line-height: 1.25rem;
    margin-bottom: .25rem;
    padding-bottom: .5rem;
    padding-top: .5rem
}

.footer-list a:last-child {
    margin-bottom: 0
}

@media (min-width: 1024px) {
    .footer-list a {
        font-size:1rem;
        line-height: 1.5rem;
        margin-bottom: .75rem
    }
}

.footer-widgets-row {
    display: flex;
    justify-content: space-between;
    gap: 1.5rem;
    border-block-end: 1px solid rgba(229, 231, 235);
}

.footer-column {
    flex: 1;
    text-align: center;
}

@media (min-width: 1024px) {
    .footer-column:nth-child(2) {
        margin-top: -45px;
        z-index: 1;
    }
}

.footer-logo {
    height: 64px;
    margin: 0 auto;
}

.contact-menu {
    text-align: initial;
    padding: 0;
}

.contact-menu li {
    padding: 2px 0;
    text-align: initial;
    display: flex;
    align-content: center;
    justify-content: center;
    flex-wrap: wrap;
    line-height: 1rem;
}

.contact-menu li span{
    line-height: 2.5;
}

.contact-menu i, .contact-menu [class^="sicon-"] {
    margin-inline-end: 10px;
    color: var(--color-link);
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    border:1px solid #374151;
    border-radius:50%;
    width: 2rem;
    height: 2rem;
}

.site-footer a {
    color: var(--color-footer-text);
}

.site-footer a:hover {
    color: var(--color-link);
}

/* Social Media Row */
.social-media-row {
    text-align: center;
    display: flex;
    justify-content: center;
    gap: 1.25rem;
}

.social-media-row a {
    align-items: center;
    border-width: 1px;
    display: flex;
    font-size: .875rem;
    height: 2rem;
    justify-content: center;
    line-height: 1.25rem;
    transition-duration: .3s;
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;
    transition-timing-function: cubic-bezier(.4,0,.2,1);
    width: 2rem;
    flex-direction: column;
    text-align: center;
    border: 1px solid var(--color-footer-text);
    opacity: .7;
    border-radius: 50%;
}


/* --- [6] Copyrights Bar --- */
.copyright-bar {
    background: var(--color-copyright-bg);
    color: var(--color-copyright-text);
    font-size: 0.85rem;
    padding: 15px 0;
}

.copyright-bar-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.payment-methods{
    align-items: center;
    display: flex;
    gap: 10px;
}

.payment-methods img {
    width: 2.5rem;
    height: 1.5rem;
    padding: .25rem;
    background-color: #fff;
    border-radius: .25rem;
}

.payment-methods i {
    font-size: 1.5rem;
    line-height: 24px;
    color: var(--color-copyright-text);
    padding: .25rem;
    background-color: #fff;
    border-radius: .25rem;
    width: 2.5rem;
    height: 1.5rem;
    text-align: center;
}

/* --- RTL Overrides and Logical Properties --- */
[dir="rtl"] {
    direction: rtl; 
    unicode-bidi: embed;
}

[dir="rtl"] .close-search {
    inset-inline-end: auto;
    inset-inline-start: 20px;
}

/* --- Media Queries and Responsiveness --- */

/* Tablet/Mobile Breakpoint (Stacking content and activating drawer) */
@media (max-width: 992px) {
    .site{
        overflow-x: hidden;
    }
    /* Mobile Menu Toggle Appearance */
    .header-icons .menu-toggle, .header-icons .empty-button {
        display: block; 
    }

    /* Hide horizontal menu and prepare for drawer */
    .main-navigation {
        /* DRAWER BASE STYLES */
        position: fixed;
        top: 0;
        inset-inline-end: 0;
        height: 100dvh; /* UPDATED: 100% Dynamic Viewport Height */
        width: 100%;
        background: var(--color-background-body);
        max-width: 440px;
        min-width: 200px;
        box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
        z-index: 10001;
        overflow-y: auto;
        transform: translateX(100%); /* LTR: Hidden off to the right */
        transition: transform 0.3s ease-in-out;
    }

    .main-navigation .container{
        padding-left: 0;
        padding-right: 0;
    }

    .main-navigation .menu-control{
        display: flex;
        border-bottom: 1px solid #DADBDD;
        font-weight: 700;
        height: 3rem;
        line-height: 2rem;
        padding-left: 1rem;
    }
    [dir="rtl"] .main-navigation .menu-control{
        padding-left: 0;
        padding-right: 1rem;
    }

    .main-navigation .btn--close{
        font-size: 1.5rem;
        height: 3rem;
        line-height: 2rem;
        top: 0;
        width: 3.5rem;
        z-index: 50;
        --tw-text-opacity: 1;
        color: #ef4444;
        color: rgba(239, 68, 68, var(--tw-text-opacity, 1));
        border: 0;
        background: transparent;
    }

    /* RTL Adjustment for Drawer */
    [dir="rtl"] .main-navigation {
        inset-inline-end: auto;
        inset-inline-start: 0;
        /* transform: translateX(calc(-100% - 440px)); */
        /* RTL: Hidden off to the left */
    }

    .main-navigation.toggled {
        transform: translateX(0); 
    }

    /* Drawer Content Styling */
    .main-navigation .nav-menu {
        display: flex !important;
        flex-direction: column;
        height: 100%;
        text-align: initial;
    }

    .main-navigation .nav-menu > li {
        width: 100%;
        margin-inline-start: 0;
    }

    .main-navigation a{
        color:var(--color-text-body);
        align-items: center;
        display: flex;
        gap: 1rem;
        padding: 18px;
        border-bottom: 1px solid #F0F0F0;
    }

    /* Footer Stacking */
    .footer-widgets-row {
        flex-direction: column;
        text-align: center;
    }
    .footer-column {
        padding-block-end: 15px;
        border-block-end: 1px dashed rgba(229,231,235);
    }
    .footer-column:first-child {
        order:1;
    }
    .footer-column:last-child {
        border-block-end: none;
        order:2;
    }

    /* Copyrights Bar Stacks */
    .copyright-bar-inner {
        flex-direction: column;
        text-align: center;
    }
    .payment-methods {
        margin-block-end: 10px;
    }
}

/* Mobile-Specific Breakpoint (Post Stacking) */
@media (max-width: 768px) {
    
    /* Top Bar Stacks */
    .top-bar .top-bar-inner {
        /* flex-direction: column; */
        align-items: center;
    }
    /* .top-bar-contact {
        margin-bottom: 8px;
    } */
    
    .top-bar-menu ul li span+span{
        display: none;
    }

    /* Added for mobile sticky header */
    .mobile-header-fixed {
        position: fixed;
        top: 0;
        animation: slideDown 0.3s ease-in-out;
    }

    @keyframes slideDown {
        from { transform: translateY(-100%); }
        to { transform: translateY(0); }
    }
}

.btn {
    align-items: center;
    display: inline-flex;
    flex: 1 1 0%;
    font-size: .875rem;
    font-weight: 700;
    justify-content: center;
    line-height: 1.25rem;
    padding: .5rem 1.5rem;
    transition-duration: .3s;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    white-space: nowrap;
    color: var(--color-link);
    border: 1px solid var(--color-link);
    flex-grow: 0;
}
.btn:hover {
    background-color: var(--color-link);
    color: var(--color-background-body);
}
.btn [class^="sicon-"] {
    transition-duration: 0.3s;
}
.transition-transform {
    transition-duration: 0.15s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}
.btn:hover [class^="sicon-"] {
    transform: translateX(-.5rem);
}

.section-title{
	text-align:center;
	max-width:42rem;
	margin-left:auto;
	margin-right:auto;
    padding-bottom: 20px;
}
.section-title .title{
	margin-top:.5rem;
	font-weight:700;
	color:var(--color-text-body);
	font-size:1.875rem;
	line-height:2.25rem;
}
@media(min-width:640px){
	.section-title .title{
		font-size:2.25rem;
		line-height:2.5rem;
	}
}
.section-title p{
	font-size:1.125rem;
	line-height:2rem;
	margin-top:.5rem;
}

.content-area {
    display: grid;
    gap: 40px;
    padding: 40px 15px;
}